威尼斯人线上娱乐

网络请求,跨域请求

28 3月 , 2019  

 1 using System.Collections;
 2 using System.Collections.Generic;
 3 using UnityEngine;
 4 using UnityEngine.Networking;
 5 using LitJson;
 6 using System.IO;
 7 using System.Net;
 8 
 9 
10 public class Connet : MonoBehaviour {
11 
12     //private ArrayList List = new ArrayList(5);
13     //private Rect rect = new Rect(10, 50, 150, 150);
14     //请求地址,写自己的请求地址就行
15     private string url = "http://xxxxxxxxx/ApiServlet?method=list";
16     //声明 JsonData     LitJson 提供的方法
17     JsonData itemdata;
18     //新建 List 存放数据
19     private List<Item> dataBase = new List<Item>();
20 
21     IEnumerator Start()
22     {
23         
24         WWW getData = new WWW(url);
25         yield return getData;
26         
27         if (getData.error != null)
28         {
29             Debug.Log(getData.error);
30         }
31         else
32         {
33             Debug.Log(getData.text);
34         }
35         //把请求到的数据转换成 JsonData array 类型,并存储到itemdata里
36         itemdata = JsonMapper.ToObject(getData.text);
37         //Debug.Log(itemdata);
38         //调用 ConstructItemDatabase() 函数
39         ConstructItemDatabase();
40         //测试数据
41         Debug.Log(dataBase[0].Name);
42     }
43     void ConstructItemDatabase()
44     {
45         //循环取数据
46         for (int i = 0; i < itemdata.Count; i++)
47         {
48             //把每个数据都添加到 dataBase 里  要和请求到的json数据对应
49             dataBase.Add(new Item((int)itemdata[i]["longId"], (int)itemdata[i]["intId"], itemdata[i]["item"].ToString()));
50         }
51     }
52 }
53 
54 //新建Item类
55 public class Item
56 {
57     //定义Item内的数据
58     //固定写法 XX{ get; set; }
59     public int ID { get; set; }
60     public int IntId { get; set; }
61     public string Name { get; set; }
62 
63     //接收上面的变量
64     public Item(int _longId, int _intId, string _name)
65     {
66         ID = _longId;
67         IntId = _intId;
68         Name = _name;
69     }
70 }

 K线图—————自定规则

http://www.baidu.com?city=beijing&weather=?
前方部分被喻为请求头 ?前面包车型大巴有的被叫做请求体
请求体由参数和参数值组成 四个参数之间用&连接
<1>依据接口划分:
假若接口是完整(包涵请求头和请求体两片段)
那种数据请求 大家就采纳GET格局呼吁数据
GET格局呼吁数据格外不难 但是不安全
请求数据的新闻都在接口的请求体地点裸揭发来 所以不安全

一般景色下大家的乞请只可以给本身的网站发送请求,如若给别的网站发送请求时,浏览器会进展同源限制,跨域请求便是我们的网站假使要博取其余网站的数码的话,能够由此须臾间办法贯彻

LitJson.dll下载地址

1.首页(自选股页面)

若是接口不完全(唯有请求头 没有请求体)
这种多少请求的主意 大家就选拔POST格局请求数据
POST方式请求数据 相对来说复杂一些 请求体需求写代码手动拼接
POST请求数据的情势日常用来登录、注册、文件的上传
<2>遵照请求数据的体制划分:

比如说:要得到以下数据

密码:1znp

    
每5秒请求1遍实时市场价格数据;每60秒请求一遍每种自行选购买股票的1分钟分时数据。离开该页面截至请求数据

同步请求:

八个请求对象向服务器请求数据 服务器会将四个对象放在队列中
2个指标初叶请求数据 其余对象在队列中等待 要是第②个对象请求数据停止之后
第2个指标才能开端请求数据 就算指标请求数据结束也要在队列中等待
等待全数目的全体伸手数据形成 服务器才将享有指标请求的数码报告给UI
全体用户体验12分倒霉 经常出现白屏获取卡顿 (也正是潜移默化了UI主线程的行事)

def get_data(request):
    return HttpResponse('数据')

前一段时间平素纠结unity连接数据库请求数据,浪费了比比皆是时日。后来改用http请求,顺利获得数量,然后就开始于解析数据,就有了这篇小说

      具体细则表达:

异步请求:

三个对象请求数据 也是将七个指标放在队列中 八个指标同时呼吁数据
何人先请求数据形成 就将数据上报给UI 无需等待别的对象达成多少请求
iOS开发中用到的数据请求都以异步请求 异步请求能够进步CPU的利用率
的确开发阳春数量有关的正是底下的4步
① 、数据请求
<1>系统类实行数量请求NSU汉兰达LConnection
<2>第②方库ASIHTTPRequest (过时)
<3>第①方库AFNetworking (盛行)
<4>系统类NSUEvoqueLSession (对NSU奥迪Q5LConnection的1次封装)
贰 、将请求下来的多少举行分析
JSON (系统类 NSJSONSerialization)
XML (系统类 NSXMLParser 第③方库GData)
③ 、将分析好的数码体未来UI上
④ 、将UI上的多少开始展览持久性存款和储蓄
NSFileHandle PList/userdefaults 归档 数据库 CoreData
NSURLConnection
拓展数量请求 只好做单任务异步请求
将三个请求职分分给多个线程 多个线程同时工作 互不干扰四个线程只可以做到当前职务的一部分 只有全体线程全体完结 整个职务才算了却
采取NSUPRADOLConnection进行数量异步请求
供给当前类遵从协议NSU帕杰罗LConnectionDataDelegate

AFNetworking
AFNetWorking 进行多少请求 不仅能请求json数据也能请求xml数据
同时期有二种多少的机动分析
AFNetWorking对NSJSONSerialization和NSXMLParser进行了三回封装

互联网请求数据(二种样式)
形式一:GET方法
方法一:
NSURubiconLConnection:(需求当前类遵守协议NSUPAJEROLConnectionDataDelegate)
<1>将字符串网址转化成NSU福特ExplorerL
NSURL * url = [NSURL URLWithString:PATH];
<2>将NSU奥迪Q5L封装成请求对象
NSURLRequest * request = [NSURLRequest requestWithURL:url];
<3>初叶异步请求
[NSURLConnection connectionWithRequest:request delegate:self];
网络请求,跨域请求。协商格局
劳动器端接收客户端的信息反映
-(void)connection:(NSURLConnection *)connection
didReceiveResponse:(NSURLResponse *)response;
始于请求数据
-(void)connection:(NSURLConnection *)connection didReceiveData:(NSData
*)data
每一种线程请求完数据未来就会调用该方法 将请求下来的数额开始展览拼接
[myData appendData:data];
呼吁数据截至
-(void)connectionDidFinishLoading:(NSURLConnection *)connection{
起始解析数据
NSDictionary * dic = [NSJSONSerialization JSONObjectWithData:myData
options:NSJSONReadingMutableContainers error:nil];
NSArray * array = dic[@”users”];
[dataSource addObjectsFromArray:array];
//数据源爆发变动 刷新表格
[table reloadData];
}
方法二 AFNetWorking
<1>创设请求操作管理者对象
AFHTTPRequestOperationManager * manager =
[AFHTTPRequestOperationManager manager];
<2>设置请求的数据类型(是json依然xml)
manager.responseSerializer.acceptableContentTypes = [NSSet
setWithObject:@”application/json”];
<3>初阶数据请求并分析
① 、请求数据的接口
2、请求体
叁 、请求数据成功、数据解析也成就了
[manager GET:<#(NSString *)#> parameters:<#(id)#>
success:<#^(AFHTTPRequestOperation *operation, id
responseObject)success#> failure:<#^(AFHTTPRequestOperation
*operation, NSError *error)failure#>]

AFNetworking能够开始展览多任务异步请求
贰个界面请求数据的接口有三个
倘若请求两个接口的数据 就要有一个呼吁对象
此地供给创立多少个请求对象 对象时期请求数据是异步的 互不烦扰
将七个对象放在队列中 实行异步请求
有着图片的接口消息
NSArray * array = @[]装有接口消息
概念2个数组 承载几个请求对象
NSMutableArray * requestArr = [[NSMutableArray alloc]init];
for(int i = 0;i<4;i++)
{
//<1>将接口转化成NSU昂科威L
NSURL * url = [NSURL URLWithString:array[i]];
//<2>将NSU卡宴L封装成请求对象
NSURLRequest * request = [NSURLRequest requestWithURL:url];
//<3>将NSURubiconLRequest对象封装成AF中的请求操作对象
AFHTTPRequestOperation * operation = [[AFHTTPRequestOperation
alloc]initWithRequest:request];
//<4>将请求下来的数码体今后UI上
[operation setCompletionBlockWithSuccess:^(AFHTTPRequestOperation
*operation, id responseObject) {
//【注意】对象请求数据 内部是同步进行数据请求的
UIImage * image = [UIImage imageWithData:responseObject];
UIImageView * imageView = (UIImageView *)[self.view viewWithTag:i +
1];
imageView.image = image;
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@”%@”,error.description);
}];
[requestArr addObject:operation];
}
成立队列对象
NSOperationQueue * queue = [[NSOperationQueue alloc]init];
设置队列中一样时刻请求数据的指标个数
queue.maxConcurrentOperationCount = 4;
将兼具请求对象放在队列中
[queue addOperations:requestArr waitUntilFinished:NO];
款式二:POST方法(POST请求 通常用来登录、注册、文件上传等操作)
方法一:
NSU昂CoraLConnection:(需求当前类遵从协议NSU卡宴LConnectionDataDelegate实现协议中务必贯彻的八个方式)
<1>将字符串网址转化成NSUCRUISERL
NSURL * url = [NSURL URLWithString:PATH];
<2>封装请求对象
[注意]GET请求 封装的恳求对象类型为NSUHavalLRequest

POST请求 封装的呼吁对象类型为NSMutableU景逸SUVLRequest
NSMutableURLRequest * request = [NSMutableURLRequest
requestWithURL:url];
<3>设置请求格局
暗许请求的格局是GET请求
[request setHTTPMethod:@”Post”]
<4>设置请求的体裁
现阶段的乞求体样式 参数名=参数值&参数名=参数值…
[request setValue:@”application/x-www-form-urlencoded”
forHTTPHeaderField:@”Content-Type”];
<5>拼接请求体
NSString * bodyStr = [NSString
stringWithFormat:@”username=%@&password=%@&email=%@”,self.nameTextField.text,self.pswTextField.text,self.emailTextField.text];
<6>设置请求体的尺寸
[注意]设置请求体的长度 设置的是呼吁体字符串对应的NSData的尺寸
NSData * bodyData = [bodyStr
dataUsingEncoding:NSUTF8StringEncoding];
[request setValue:[NSString
stringWithFormat:@”%d”,(int)bodyData.length]
forHTTPHeaderField:@”Content-Length”];
<7>将请求体拼接到请求头后边
[request setHTTPBody:bodyData];
<8>开端请求数据
[NSURLConnection connectionWithRequest:request delegate:self];
方法二 AFNetWorking
//<1>创设请求操作管理那对象
AFHTTPRequestOperationManager * manager =
[AFHTTPRequestOperationManager manager];
<2>设置接收的数据类型
manager.responseSerializer.acceptableContentTypes = [NSSet
setWithObject:@”text/html”];
<3>拼接请求体
AFNetworking进行post请求 请求体拼接使用字典封装
字典的键为接口文书档案中的参数名 字典中的值为参数值
NSDictionary * dic =
@{@”username”:self.nameTextField.text,@”password”:self.pswTextField.text};
<4>先河请求数据并分析
[manager POST:LOGINPATH parameters:dic success:^(AFHTTPRequestOperation
* _Nonnull operation, id _Nonnull responseObject)
{
NSString * message = responseObject[@”message”];
威尼斯人线上娱乐 ,NSString * code = responseObject[@”code”];
} failure:^(AFHTTPRequestOperation * _Nonnull operation, NSError *
_Nonnull error) {
NSLog(@”%@”,error.description);
}];

利用代码达成跨域请求

request发送请求的时候跨域无界定

def test1(request):
    response = requests.get('http://127.0.0.1:8000/get_data/')
    return render(request, 'test1.html', {'response': response})

在前端展现

{{ response.text }}

一经咱们看不懂,那里有一个视频讲的依然分外详细的

    
(1)实时市价:只要用户在该页面,不分白天夜间,开盘收盘,每5秒请求三次;离开该页面,请求结束;每收到实时市价补偿到分时小图中

     
(2)分时小图:竞价排名和连接撮合时期,每60秒请求一遍;其余时间,若本地无分时数据,请求三回,若有,不请求分时数据;

  2.个股页(股票详情页)

jsonp完毕跨域请求

外人数据

def get_data(request):
    func_name = request.GET.get('callback')
    return HttpResponse('%s("数据")' % func_name)

接纳jsonp达成跨域请求

<script>
    function func(arg){
        console.log(arg)
    }

    $.ajax({
        url: "http://127.0.0.1:8000/get_data/",
        type: 'GET',
        dataType: 'JSONP',
        jsonp: 'callback',
        jsonpCallback: 'list'
    });

</script>

注意:

率先,要让别人对数码进行拍卖

其次,为了让取得的多寡易读,需求将数据开始展览list

其原理是利用含有src的标签不会接受同源限制,而且供给本人定义2个数目,使用标签引入,而且供给别人也要在数据外面包一层数据,如下

友善赢得

<script>
  function func(arg) {
    console.log(arg);
  }
</script>
<script src="http://127.0.0.1:8000/get_data/?callback=func"></script>

大家也得以手动创立标签

<script>
    function func(arg) {
        alert(arg);

        document.head.removeChild(tag);
    }

    function jsonp(url){
        tag = document.createElement('script');
        tag.src = url;
        document.head.appendChild(tag);
    }

    jsonp('http://127.0.0.1:8000/get_data/?callback=func')
</script>

利用场景:

调用者需求和数量提供者协商,首先须求多少提供者提供三个API,然后相互切磋使用哪类办法领取数额,假设运用jsonp格式提取数额的话须求多少提供者对数据开始展览自然的拍卖(获得callback,然后使用callback包裹你的数目),假设不想让多少提供者麻烦的话,就不得不用自带的request模块来落到实处

       用户停留该页面时,每5秒请求1遍实时市场价格数据;离开该页面停止请求

core方法

第①要通晓,jsonp举办跨域请求的点子是绕过同源策略,使用带有src的标签实行呼吁

其次,浏览器为何会进展同源策略,其实在伸手能够顺遂的到达对方的U中华VL,也同等能取到数码,然则在回到的时候少了Access-Control-Allow-Origin
响应头,由此,大家的做法便是将头加进去

别人数据

def get_data(request):
    response = HttpResponse('数据')
    response['Access-Control-Allow-Origin'] = 'http://127.0.0.1:8899'  # 如果为*的话对所有请求有效
    return response

那样让别人的多少开始展览处理现在大家温馨就遵照一般景观请求就足以了

$.ajax({
  url: 'http://127.0.0.1:8000/get_data/',
  type: 'GET',
  success: function (data) {
    console.log(data);
  }
})

比方大家给外人提供数据的话,若是允许全部的人都可以请求的话,使用中间件比较好

      
(1)若页面显示分时图,每60秒请求当日分时数据,每5秒请求该股票当日最终五组分时数据;离开该页面结束请求

       
(2)若页面显示日K图,每60秒请求该股票的日K数据;离开该页面甘休请求

      具体细则表达:

      
(1)实时行情:只要用户在该页面,不分白天夜晚,开盘收盘,每5秒请求实时市价;离开该页面,请求停止

      
(2)分时图:竞价排行和一而再撮合时期,每60秒请求1遍当日分时数据,每5秒请求一次当日分时的最后五组数据;其余时间,若本地无分时数据,请求一次;若有,不请求分时数据;

      
(3)日K图:竞价排行和连接撮合时期,每60秒请求二次日K数据,每5秒判断实时行情和日K末了一组数据的最大相当小值实行补缺;别的时间,若本地无日K数据,请求三遍;若有,不请求日K数据;

注意:

小编门正规的央求称为不难请求,不过,有时候发请求的时候会发送复杂请求,请求格局改变也许请求头的更改能够成为复杂请求,

借使发送的是参差不齐请求的话,首先会发送四个option,然后发送数据,复杂请求接受到的request.method是option

为此数据提供者应该在接受请求的时候进行2个断定,假如request.method的话,将呼吁情势和央浼头举行修改,然后再发送数据

鉴于复杂请求发送一次,严重影响功效,因而大家应该尽量制止发送复杂请求

极度复杂请求代码如下

def get_data(request):
    if request.method == "OPTIONS":
        # 预检
        response = HttpResponse()
        response['Access-Control-Allow-Origin'] = "*"
        # response['Access-Control-Allow-Methods'] = "PUT"
        response['Access-Control-Allow-Headers'] = "xxx"   # 注意在前端也是要一样的
        return response

    elif request.method == "GET":
        response = HttpResponse("机密数据")
        response['Access-Control-Allow-Origin'] = "*"

        return response

跨站获取相应头

暗中认可获取到的保有响应头只有着力新闻,假如想要获取自定义的响应头,则须求再服务器端设置Access-Control-Expose-Headers。

跨站传cookie

在跨域请求中,默许情形下,HTTP
Authentication消息,Cookie头以及用户的SSL证书无论在预检请求中可能在实际上请求都以不会被发送。

设若想要发送:

  • 浏览器端:XMLHttpRequest的withCredentials为true
  • 劳务器端:Access-Control-Allow-Credentials为true
  • 留神:服务器端响应的 Access-Control-Allow-Origin 不可能是通配符

  3.股友动态页

      
用户停留在该页面时,每5秒请求二次实时市场价格;每60秒请求三次该股票的分时数据;离开该页面,截至请求

现实细则表明:

       
(1)实时物价指数:只要用户在该页面,不分白天晚间,开盘收盘,每5秒请求3遍实时市场价格;每隔5秒补偿到分时小图中。离开该页面,请求甘休

      
(2)分时小图:竞价排行和接二连三撮合期间,每60秒请求一次,别的时间,若本地无分时数据请求贰次,若有,不请求分时数据;离开该页面,请求截止。

4.横屏页

      用户在该页面时,每5秒请求壹次实时汇兑,别的:

    (1)分时数据
每60秒请求三回当日分时数据,每隔5秒请求2次当日分时最终五组数据

    (2)5日分时每60秒请求3遍

   
(3)竞价排名和一而再撮合期,日K,周K,月K每60秒请求3次,别的时间,若本地无分时数据请求一回,若有,不请求;

    具体细则表达:

      (1)实时物价指数只要停留在该页面总会不停刷新;

     
(2)五档数据包涵在实时市价数据中,不需求别的请求,每5秒和实时市场价格一起刷新界面

  
(3)用户切换(分时,10日分时,日K,周K,月K)到该项才运行该项网络请求;比如用户切换成日K,别的类型请求结束(分时,1日分时,周K,月K),日K请求运转


相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图