博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JQuery和Servlet来实现跨域请求
阅读量:6408 次
发布时间:2019-06-23

本文共 3053 字,大约阅读时间需要 10 分钟。

在网上看到很多的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 =
""
;//远程请求地址
    
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"
;
        
}
    
}
     
}

转载于:https://www.cnblogs.com/ranran/p/jquery_soklet.html

你可能感兴趣的文章
cad填充图案乱理石_太快了吧!原来大神是这样用CAD图案填充的
查看>>
activator.createinstance 需要垃圾回收么_在垃圾回收器中有哪几种判断是否需要被回收的方法...
查看>>
rocketmq 消息指定_RocketMQ入坑系列(一)角色介绍及基本使用
查看>>
redis zset转set 反序列化失败_掌握好Redis的数据类型,面试心里有底了
查看>>
p图软件pⅰc_娱乐圈最塑料的夫妻,P图永远只P自己,太精彩了吧!
查看>>
jenkins 手动执行_Jenkins 入门
查看>>
怎么判断冠词用a还是an_葡语干货 | 葡萄牙语冠词用法整理大全
查看>>
js传参不是数字_JS的Reflect学习和应用
查看>>
三个不等_数学一轮复习05,从函数观点看方程与不等式,记住口诀与联系
查看>>
卡尺测量的最小范围_汽车维修工具-测量用具
查看>>
网优5g前景_5G网络优化师前景怎么样?
查看>>
竞态条件的赋值_[译] part25: golang Mutex互斥锁
查看>>
delmatch oracle_完美完全卸载(清除)oracle数据库的方式(方法)
查看>>
pyqt 滚动条 美化_Pyqt5 关于流式布局和滚动条的综合使用示例代码
查看>>
51单机片 编译hex_单片机爬坑记-05-编译环境(完)
查看>>
java 正则表达式 img_Java正则表达式获得html字符串里的<img src=""/> 中的url列表
查看>>
java 文件crc校验_一个获取文件crc32校验码的简洁的java类 | 学步园
查看>>
java flatmapfunction_Java8 Stream flatmap中间操作用法解析
查看>>
java rmi spring 4.0_Java Spring RMI一些尝试
查看>>
JAVA怎么连接华为的HDFS系统_JAVA-API操作HDFS文件系统(HDFS核心类FileSystem的使用)...
查看>>