Angular最新教程-第七节HTTP get post 设置头部 跨域访问

简介: Angular最新教程-第七节HTTP get post 设置头部 跨域访问

和angular1一样angular4也有http库,用来调用外包的API。
为了不使发起的请求,导致当前进入等待而没有响应,HTTP请求都是异步的。
这个之前我们聊过类似的,JavaScript中的异步处理方法。
1、callback回调的方式。
2、promise,这个可以参考我很早之前的一篇博客。
http://blog.csdn.net/onil_chen/article/details/51099443
3、observable可观察对象。(这个后续讲解,这里先记住Angular中处理异步的最佳方式就是这个。)
(以上语言组织参考了ng-book 2)


接下来我们来讨论如何在我们的项目中使用http
跟ng1不同的是,ng1是内置的http模块。
ng4需要我们在使用之前导入HttpModule


使用@angular/http


使用request、get请求

打开\src\app\app.module.ts
头部加入import { HttpModule } from ‘@angular/http’;
在imports中加入HttpModule,如下。

image.png

然后我们就可以在任何使用依赖注入的地方使用http服务了。
这里我们先简单的实现一下。
打开\src\app\site-status\site-status.component.ts(第五节课代码
http://blog.csdn.net/onil_chen/article/details/78063916
在头部import导入http和response对象。
然后定义构造函数constructor,注入模块Http。
然后再页面初始化函数中调用,请求api。

image.png

保存运行。

image.png

这里请求报错,是因为不同源问题导致的,也就是常说的跨域。
之前1中我们处理跨域访问是使用设置CORS(全称Cross-Origin Resource Sharing)的方式来实现的。


但是这个需要服务端的支持,因为我们用的是angular中文社区的api,(我直接8的。)
所以我们使用反向代理的方式来实现。这个是angular/cli的一个内置功能。

image.png

简要说明就是在根目录创建一个文件。 proxy.conf.json,在文件里面设置代理到哪个地址。
然后在package.json中设置
"start": "ng serve --proxy-config proxy.conf.json",
最后使用
npm start 运行项目(注意不要直接使用ng serve,不然代理不会生效,也可以运行ng serve --proxy-config proxy.conf.json )。

image.png

修改\src\app\site-status\site-status.component.ts中的请求地址。
然后将请求回来的数据绑定到页面上(数据要先处理,后续讲解)。

image.png

我们从浏览器的NetWork中查看一下请求。
浏览器显示我们请求的地址是
http://localhost:4200/api/index

image.png

但是实际上却有数据返回,而且返回的数据是http://www.angularjs.cn上的

image.png

这里我们可以对比一下,我们本地请求的数据确实是angularjs中文社区网站的数据。

image.png

到这里我们的第一个http请求就完成了。
get和上面使用的request一样的用法。
接下来我们看如何发起post请求。


使用post请求

image.png

主要代码如下,第一个参数和get一样为请求地址。第二个参数为请求的body。第三个参数设置头部一起说。
简要例子如下:

this.http.post('/api/index',
{
  name:"xiaohuoni",
  author:"mangfu"
}).subscribe((res:Response)=>{})


使用PUT\PATCH\DELETE\HEAD

这些请求和get类似,也不常用,这里不讲解。
可查阅api或者在编译器中查看,如上图post。


设置头部

我们刚刚在查阅post的参数说明时,最后一个参数,是options?:RequestOptionsArgs
其实所有的http方法的最后一个参数都是它。
RequestOptionsArgs其实是请求对象的封装。
里面包括method、headers、body、mode、credentials、cache、url、search
以下我们以设置headers为例。

image.png

不要忘了在头部加入import { Http , Response ,Headers} from '@angular/http';


源代码:百度云 链接:http://pan.baidu.com/s/1jHYc8g2 密码:xjj6
码云:
https://gitee.com/xiaohuOni/oniplan-ng
有码云的帮忙给个star,感谢。


这节课的内容就到这里完成了。
感谢您的阅读。
我是莽夫,希望你开心。

目录
相关文章
|
Linux C语言 iOS开发
C语言结合AWTK开发HTTP接口访问界面
这样,我们就实现了在C语言中使用libcurl和AWTK来访问HTTP接口并在界面上显示结果。这只是一个基础的示例,你可以根据需要添加更多的功能和优化。例如,你可以添加错误处理机制、支持更多HTTP方法(如POST、PUT等)、优化用户界面等。
692 82
|
11月前
|
安全 Linux 定位技术
Curl访问Kerberos SPNEGO保护的HTTP资源
最后,记住,虽然Kerberos的魔法强大且久经考验,但它仍需你谨慎掌握。SPNEGO的舞步看似复杂,但一旦跳起来,你会发现自己在安全和便捷的旋律中翩翩起舞。而Curl,这一灵活敏捷的小工具,它的确有能力成为你施展这些魔法的得力助手。
317 14
|
监控 安全 搜索推荐
设置 HTTPS 协议以确保数据传输的安全性
设置 HTTPS 协议以确保数据传输的安全性
|
Go
在golang中发起http请求以获取访问域名的ip地址实例(使用net, httptrace库)
这只是追踪我们的行程的简单方法,不过希望你跟着探险家的脚步,即使是在互联网的隧道中,也可以找到你想去的地方。接下来就是你的探险之旅了,祝你好运!
632 26
|
UED
在 angular 中设置合适的变更检测策略
【10月更文挑战第4天】
503 156
探寻HTTP代理IP访问站点失败的背后因素
随着互联网发展,使用HTTP动态代理IP的人越来越多。但有时使用代理后仍无法访问站点,原因包括:1. IP失效;2. 网络质量差;3. 浏览器或程序设置错误;4. 需尝试其他代理商;5. 联系网站管理员;6. 不符合目标站点规范。选择高质量的代理服务商可提升访问成功率。
483 2
|
关系型数据库 MySQL Docker
docker pull mysql:8.0.26提示Error response from daemon: Get “https://registry-1.docker.io/v2/“: EOF错误
docker pull mysql:8.0.26提示Error response from daemon: Get “https://registry-1.docker.io/v2/“: EOF错误
4903 9
|
应用服务中间件 Linux 网络安全
nginx安装部署ssl证书,同时支持http与https方式访问
为了使HTTP服务支持HTTPS访问,需生成并安装SSL证书,并确保Nginx支持SSL模块。首先,在`/usr/local/nginx`目录下生成RSA密钥、证书申请文件及自签名证书。接着,确认Nginx已安装SSL模块,若未安装则重新编译Nginx加入该模块。最后,编辑`nginx.conf`配置文件,启用并配置HTTPS服务器部分,指定证书路径和监听端口(如20000),保存后重启Nginx完成部署。
5263 8

热门文章

最新文章