当前位置: 首页 > news >正文

JQuery和Servlet来实现跨域请求

在网上看到很多的JQuery跨域请求的文章,比较有意思。这里我发表一个Servlet与JQuery配置实现跨域的代码,供大家参考。不足之处请指教

原理:JavaScript的Ajax不可以跨域,但是可以通过向本地的一个Servlet发出请求,由Servlet完成跨域。再把远程的结构返回给客户端。这样Ajax就可以跨域了。在后面,再发一个PHP版本的,请大家关注啊。下面是代码

JS代码:

注意:在Post方式时,param1和param2为向远程发送的参数值,可以有多个。

 

1
2
3
4
5
6
7
8
9
10
11
12
//GET方式
function reqeustCrossDomainProxyGet(){
     var url = "http://www.baidu.com" ;//远程请求地址
     var param = { 'requesturl' :url, 'typedata' : 'JSON' };
     var data = getCrossDomainProxyRemote(param, "json" );
}
//Post方式
function reqeustCrossDomainProxyPost(param1,param2){
     var url = apiServer+ "/api/lucene/query" ;
     var param = { 'requesturl' :url, 'typedata' : 'JSON' , 'param1' :param1, 'param2' :param2};
     var data = getCrossDomainProxyRemote(param, "json" );
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/**
  * JS向本址的一个Servlet发送POST请求,所有关于远程请求的参数。
  * 在此处参POST方式发送给Servlet
  * @param param 远程请求参数
  * @param rtype JS返回类型(暂时没有用到)
  * @return
  */
function getCrossDomainProxyRemote(param,rtype){
     var url = "/cross/proxy" ; //Servlet的URL地址
     var returndata;
     $.ajax({
         url: url,type: 'POST' ,dataType: rtype,timeout: 40000,data:param, async: false ,
         error: function (response,error) {alert(response.status);},
         success: function (data){returndata=data;}
     });
     return returndata;
}

Java代码:

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
public class CorssDomainProxy extends HttpServlet {
     
     public void doGet(HttpServletRequest req, HttpServletResponse resp)
             throws ServletException, IOException {
         this .doPost(req, resp);    
     }
     
     public void doPost(HttpServletRequest req, HttpServletResponse resp)
             throws ServletException, IOException {
         boolean requestType = false ; //标记远程请求类型,默认为GET方式
         PrintWriter out = resp.getWriter();
         Enumeration keys = req.getParameterNames(); //取出客户端传入的所有参数名
         ArrayList<String> params = new ArrayList<String>();
         String url= null ;
         while (keys.hasMoreElements()){
             String key = (String) keys.nextElement();
             /**
              * 如果请求参数内有如下几种表示,这此参数不参与远程请求
              */
             if (key.equals( "requesturl" )){ //判断参数是否是,远程请求地址
                 url = req.getParameter(key);
             } else if (key.equals( "typedata" )){ //判断请求数据类型,暂时没有用到
                 
             } else if (key.equals( "returntype" )){ //判断请求返回类型,暂时没有用到
                 
             } else {
                 params.add(key); //其它加入参数列表,此处为参与远程请求的参数
                 requestType = true ; //修改标记,表求远程请求为POST方式
             }
         }
         
         HttpClient client = new HttpClient();
         HttpMethod method = null ;
         if (requestType){ //判断请求方式,并实例化HttpMethod对象,true:POST,false:GET
             method = new UTF8PostMethod(url);
             for (String name : params){ //迭代POST参数,加入到请求中
                 String _value = req.getParameter(name);
                 ((PostMethod)method).setParameter(name,_value);
             }
         } else {
             method = new GetMethod(url);
         }      
         client.executeMethod(method); //执行请求
         String bodystr = method.getResponseBodyAsString(); //返回结果
         out.println(bodystr); //将结果返回给客户端
     }
     
     /**
      * 内部类,转换URL字符串为UTF-8
      * @author Administrator
      *
      */
     private static class UTF8PostMethod extends PostMethod {
         public UTF8PostMethod(String url) {
             super (url);
         }
         @Override
         public String getRequestCharSet() {
             return "UTF-8" ;
         }
     }
     
}

相关文章:

  • 线程同步机制
  • PHP泛域名应用
  • keytool 用法总结
  • MediaPlayer视频播放
  • Android文本框实现搜索和清空效果
  • strongweak
  • powershell最常用的命令之(一)
  • 左固定右边自适应框架
  • logrotate工具的使用
  • ping,
  • php操作mysql数据库类代码
  • 恶补英语-1
  • 随机选择实现
  • 重读金典------高质量C编程指南(林锐)-------第六章 函数设计
  • Oracle 修改表列属性
  • Apache的80端口被占用以及访问时报错403
  • express如何解决request entity too large问题
  • javascript从右向左截取指定位数字符的3种方法
  • JavaScript类型识别
  • java小心机(3)| 浅析finalize()
  • Laravel 中的一个后期静态绑定
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • Python代码面试必读 - Data Structures and Algorithms in Python
  • Redis的resp协议
  • spring boot下thymeleaf全局静态变量配置
  • Vim Clutch | 面向脚踏板编程……
  • vue-cli在webpack的配置文件探究
  • vue-loader 源码解析系列之 selector
  • Vue源码解析(二)Vue的双向绑定讲解及实现
  • webpack4 一点通
  • 持续集成与持续部署宝典Part 2:创建持续集成流水线
  • 目录与文件属性:编写ls
  • 一个项目push到多个远程Git仓库
  • 找一份好的前端工作,起点很重要
  • No resource identifier found for attribute,RxJava之zip操作符
  • 如何正确理解,内页权重高于首页?
  • ​2020 年大前端技术趋势解读
  • #pragma once与条件编译
  • #pragma预处理命令
  • (4) PIVOT 和 UPIVOT 的使用
  • (草履虫都可以看懂的)PyQt子窗口向主窗口传递参数,主窗口接收子窗口信号、参数。
  • (附源码)springboot宠物管理系统 毕业设计 121654
  • (每日持续更新)jdk api之StringBufferInputStream基础、应用、实战
  • (算法)N皇后问题
  • (原創) 如何安裝Linux版本的Quartus II? (SOC) (Quartus II) (Linux) (RedHat) (VirtualBox)
  • (转)http协议
  • .apk文件,IIS不支持下载解决
  • .net 4.0 A potentially dangerous Request.Form value was detected from the client 的解决方案
  • .NET Core 2.1路线图
  • .NET 将多个程序集合并成单一程序集的 4+3 种方法
  • .NET 使用配置文件
  • .NET企业级应用架构设计系列之应用服务器
  • .NET中的十进制浮点类型,徐汇区网站设计
  • .Net转Java自学之路—基础巩固篇十三(集合)
  • /etc/fstab 只读无法修改的解决办法