zoukankan      html  css  js  c++  java
  • ajax跨域请求

    1、httpclient代理处理跨域请求。

    1.1、请求服务器的xml

    (1)服务器端

    CloseableHttpClient httpClient = HttpClients.createDefault();
    		HttpGet httpGet = new HttpGet("http://fanyi.youdao.com/openapi.do?keyfrom=<keyfrom>&key=<key>&type=data&doctype=xml&version=1.1&q="+request.getParameter("q"));
    		try {
    			CloseableHttpResponse httpResponse = httpClient.execute(httpGet);
    			HttpEntity entity = httpResponse.getEntity();
    			if(entity !=null){
    				String tmp = EntityUtils.toString(entity);
    				httpResponse.close();
    				response.setContentType("text/xml;charset=utf-8");
    				PrintWriter out = response.getWriter();
    				out.print(tmp);
    				out.flush();
    				out.close();
    			}
    		} catch (Exception e) {
    			e.printStackTrace();
    			System.out.println(e.getMessage());
    		}finally{
    		}
    

     (2)客户端

    $.ajax({
    					type:"get",
    					url:"/Ajax/fanyi.do",
    					data:"q=good",
    					success:function(xml){
    						var data = "";
    						data += $(xml).find("query").text();
    						data += $(xml).find("translation").text();
    						data += $(xml).find("basic").text();
    						$("#status").text(data);
    					}
    				});
    

    1.2 请求服务器的json格式

    (1)服务器端

    CloseableHttpClient httpClient = HttpClients.createDefault();
    		HttpGet httpGet = new HttpGet("http://fanyi.youdao.com/openapi.do?keyfrom=<keyfrom>&key=<key>&type=data&doctype=json&version=1.1&q="+request.getParameter("q"));
    		try {
    			CloseableHttpResponse httpResponse = httpClient.execute(httpGet);
    			HttpEntity entity = httpResponse.getEntity();
    			if(entity !=null){
    				String tmp = EntityUtils.toString(entity);
    				httpResponse.close();
    				response.setContentType("application/json;charset=utf-8");
    				PrintWriter out = response.getWriter();
    				out.print(tmp);
    				out.flush();
    				out.close();
    			}
    		} catch (Exception e) {
    			e.printStackTrace();
    			System.out.println(e.getMessage());
    		}finally{
    		}
    

    (2)客户端

    $.ajax({
    					type:"get",
    					url:"/Ajax/fanyi.do",
    					data:"q=good",
    					success:function(data){
    						$("#status").text(data.translation);
    					}
    				});
    

      

  • 相关阅读:
    Node.js中的Buffer
    移动端页面弹出对话框效果Demo
    简单编写makefile文件,实现GCC4.9编译项目,增加boost库測试等等。。
    Windows下使用静态库
    将 Android* Bullet 物理引擎移植至英特尔&#174; 架构
    Java读书笔记一(异常处理)
    设计模式
    Ignatius and the Princess III(杭电1028)(母函数)
    oracle树操作(select .. start with .. connect by .. prior)
    三期_day02_数据库表设计和开发准备工作
  • 原文地址:https://www.cnblogs.com/hpustudent/p/4099269.html
Copyright © 2011-2022 走看看