zoukankan      html  css  js  c++  java
  • java之初识服务器跨域获取数据

    当一个项目膨大到无法进行整理时,而作为新负责维护的团队是非常苦恼的。对于想实现两个系统的数据访问,使用Ajax数据请求方式获取jsonp格式的数据

    需要有前端jquery库文件。

    前端代码通过jquery的处理方式如下:

    $.ajax({
            type : "get", //jquey是不支持post方式跨域的
            async:false,
            url : "http://192.168.0.113:8080/test/", //跨域请求的URL
            dataType : "jsonp",
            //传递给请求处理程序,用以获得jsonp回调函数名的参数名(默认为:callback)
            jsonp: "callback",
            //自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名
            jsonpCallback:"success_jsonpCallback",
            //成功获取跨域服务器上的json数据后,会动态执行这个callback函数
            success : function(json){ 
              alert(json.name); 
            } 
        }); 

    这时候,我是通过原生servlet进行测试的,通过获取jsonp的参数callback就可以拿到这个方法名字。

    public class ServletTest extends HttpServlet {
    
        private final String gdtcUrl = "http://www.xxxxx
    .cn/"; /** * 毫秒 */ private final long delayTime = 60 * 1000; /** * 定时器 */ private Timer mTimer = null; /** * 缓存json */ private String cashJson = null; @Override public void init() throws ServletException { String params = getInitParameter("iniParam"); System.out.println(params); mTimer = new Timer(); mTimer.schedule(new TimerTask() { @Override public void run() { List<ModuleBean> datas = JdbcConnection.getFast5Hm(); cashJson = JSON.toJSONString(datas); System.out.println("数据定时来了:" + cashJson); } }, 0, delayTime); } @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doPost(req, resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setCharacterEncoding("GBK"); resp.setContentType("text/plain;charset=UTF-8"); String referer = req.getHeader("Referer"); System.out.println("来访地址:" + referer); if (referer != null && referer.startsWith(gdtcUrl)) { // 当缓存为空时,请求一次数据库 if (cashJson == null) { cashJson = JSON.toJSONString(JdbcConnection.getFast5Hm()); }
             String renderStr
    = req.getParameter("callback") + "(" + cashJson + ")"; resp.getWriter().write(renderStr); } else { resp.getWriter().write("error of no authority"); } resp.getWriter().flush(); } }

    上面这种方式利用了缓存策略,把查询的数据缓存下来,缓解了服务器压力

    通过referer对访问地址进行安全限制。重要的是把json数据拼接成jsonp格式返回给了前端ajax那个callback回调方法

    初次在项目上着手后台,希望以后能有更大的进步

  • 相关阅读:
    4.20 每日一练
    4.19 每日一练
    4.18 每日一练
    Python函数初
    Python的文件操作
    python购物车
    python深浅拷贝,集合以及数据类型的补充
    Python 代码块 小数据池
    Python字典
    Python 列表操作
  • 原文地址:https://www.cnblogs.com/taofudemo/p/6121317.html
Copyright © 2011-2022 走看看