转载自:http://blog.youkuaiyun.com/sujun10 作者:弃天笑
- 最主要是服务端支持服,返回的时候必须增加一个Header
AddHeader("Access-Control-Allow-Origin","*");
实际部署的时候,* 应该修改为指定的域名
2. 客户端使用XMLHttpRequest,但是也要增加一个Header
setRequestHeader("Content-Type", "application/x-www-form-urlencoded;charset=UTF-8");
后面看具体的使用例子了。
二、使用XMLHttpRequest
var XMLHttp = new XMLHttpRequest();
XMLHttp.withCredentials = false;
XMLHttp.onreadystatechange = function()
{
if(XMLHttp.readyState === 4)
{
if(XMLHttp.status === 200)
{
console.log(XMLHttp.responseText);
var result = JSON.parse(XMLHttp.responseText);
if(result.errorCode == 0)
{
}
else
{
alert(result.errorMessage);
}
}
else
{
alert("Request was failure: " + XMLHttp.status);
}
}
};
var url = 'http://192.168.0.166:8080/game/cmgeLogin';
XMLHttp.open('POST', url, true);
XMLHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;charset=UTF-8");
XMLHttp.send();
- 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
如果是老版本的ID,还得做兼容的检测
getXmlHttpRequest = function()
{
if (window.XMLHttpRequest)
{
return new XMLHttpRequest();
}
else if (window.ActiveXObject)
{
return new ActiveXObject("Microsoft.XMLHttpRequest");
}
};
三、使用白鹭的API
使用Egret自己封装的RES就非常简洁了,普通页面返回文本
RES.getResByUrl(url,function(data:string):void
{
console.log(data);
},this,RES.ResourceItem.TYPE_TEXT);
处理返回json格式的结果
RES.getResByUrl(url,function(data:Object):void
{
console.log(data);
},this,RES.ResourceItem.TYPE_JSON);
使用egret.URLLoader
var url:string = this.config.loginUrl;
this.loginLoader = new egret.URLLoader();
this.loginLoader.dataFormat = egret.URLLoaderDataFormat.TEXT;
var request:egret.URLRequest = new egret.URLRequest();
request.requestHeaders = [new egret.URLRequestHeader("Content-Type", "application/x-www-form-urlencoded;charset=UTF-8")];
request.url = this.config.loginUrl + "?gameUID=sword&channelUID=cmge&cmgePlayerId=lgl123321&loginTime=1496741695&sign=23456789";
this.loginLoader.addEventListener(egret.Event.COMPLETE,function(evt:egret.Event):void
{
var data:string = this.loginLoader.data;
console.log(data);
},this);
this.loginLoader.load(request);
也可以使用白鹭的HttpRequest
var httpRequest:egret.HttpRequest = new egret.HttpRequest();
httpRequest.responseType = egret.HttpResponseType.TEXT;
httpRequest.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;charset=UTF-8");
httpRequest.addEventListener(egret.Event.COMPLETE,function(evt:egret.Event):void
{
var data:string = httpRequest.response;
console.log(data);
},this);
httpRequest.open("http://192.168.0.166:8080/game/cmgeLogin",egret.HttpMethod.POST);
httpRequest.send();
这里要注意的是,必须增加一个RequestHeader,也就是
"Content-Type", "application/x-www-form-urlencoded;charset=UTF-8"
否则会提示下面的错误的:
XMLHttpRequest cannot load http://192.168.0.166:8080/game/cmgeLogin. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:63342' is therefore not allowed access. The response had HTTP status code 400.
Uncaught Error:
_error
(anonymous function)
基本上,Egret所封装的api足够使得我们去从其他的web服务器获取所需要的数据了。