curl
目前创新互联已为超过千家的企业提供了网站建设、域名、虚拟空间、网站托管、企业网站设计、石景山网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
curl 是常用的命令行工具,用来请求 Web 服务器。它的名字就是客户端(client)的 URL 工具的意思。curl 功能非常强大,它的命令可以直接放到 postman 使用,postman 也是支持 curl 的请求方式。
常用的结果参数
curl 的参数包括很多,这里只说几个常用的,如果遇到复杂情况可以参考文档。
不知道是不是还有的小伙伴不知道 postman 直接支持 curl 命令,在 postman 中点击 code 就会出现对应请求的curl命令
curl 项目中应用
如果对 curl 熟悉的小伙伴完全可以替代 postman 等工具,小伙伴可以直接模拟请求。(我认为curl能看到懂常用命令就够了)
因为在 BFF 项目中,好多时候前端也参与开发,我们也会直接调用后端的接口,有时候报错不知道是不是自己参数写错了,或者 cookie 有问题,找问题调试不方便,在 local 环境下,我们会直接打印出完整的 curl 请求,这时候可以直接看出错误,开发者只需要知道 curl 的一些参数就可以,还可以直接把 curl 命令复制到 postman 进行调试。看一下具体实现部分代码
- //只在本地环境输出
- if (ctx.app.config.env === 'local') {
- const str =
- curlString(url, {
- method,
- headers,
- body,
- }) + '\n';
- console.log('\x1b[32m%s\x1b[0m', str);
- }
- /**
- * Builds a curl command and returns the string.
- * @param {String} url Endpoint
- * @param {Object} options Object with headers, etc. (fetch format)
- * @return {String} cURL command
- */
- function curlString(url, options) {
- const method = options && options.method && typeof options.method === 'string' ? options.method.toUpperCase() : 'GET';
- const hasHeaders = options && options.headers && typeof options.headers === 'object';
- const hasBody = options && options.body;
- let curl = `\ncurl --request ${method} \\\n--url '${url}'`;
- if (hasHeaders) {
- curl +=
- ' \\\n' +
- Object.entries(options.headers)
- .filter(([key, value]) => value !== undefined)
- .map(([key, value]) => `--header '${key}: ${value}'`)
- .join(' \\\n');
- }
- if (hasBody) {
- curl += ` \\\n--data '${bodyToDataString(options)}'`;
- }
- return curl;
- }
- /**
- * Constructs a body string for use inside --data
- * @param {Object} options Object with headers, etc. (fetch format)
- * @return {String} cURL command data string
- */
- function bodyToDataString(options) {
- let parsedData;
- try {
- parsedData = JSON.parse(options.body);
- } catch (e) {
- // fall back to original body if it could not be parsed as JSON
- parsedData = options.body;
- }
- // return an ampersand delimited string
- const headers = _.get(options, 'headers');
- const contentType = _.toLower(_.get(headers, 'content-type') || _.get(headers, 'Content-Type'));
- if (contentType === 'application/x-www-form-urlencoded') {
- if (typeof parsedData === 'string') {
- return parsedData;
- } else {
- return Object.entries(parsedData)
- .map(([key, val]) => `${key}=${val}`)
- .join('&');
- }
- } else {
- return JSON.stringify(parsedData);
- }
- }
vim 中的基本操作和配置
非 insert 模式
在 vim 打开文件后,还没有使用插入编辑,可以做哪些基本操作
insert 模式
前面说了多种移动方式,接下来结束几个常用的 insert 命令,我这里就结束一些常用简单的
ping
在网络中 ping 是一个十分强大的 TCP/IP 工具。
bytes值:数据包大小,也就是字节。
time值:响应时间,这个时间越小,说明你连接这个地址速度越快。
TTL值:Time To Live,表示DNS记录在DNS服务器上存在的时间,它是 IP 协议包的一个值,告诉路由器该数据包何时需要被丢弃。可以通过 Ping 返回的 TTL 值大小,粗略地判断目标系统类型是 Windows 系列还是 UNIX/Linux 系列。
默认情况下,Linux 系统的TTL值为64或255,WindowsNT/2000/XP 系统的 TTL 值为 128,Windows98 系统的 TTL 值为32,UNIX 主机的 TTL 值为 255。
除了直接 ping ip ,还可以 ping 域名,会自动把域名解析为 ip。
应用
最常用的方式是直接ping ip地址,测试网络连通性
学会看懂出错提示信息
(1)NoAnswer:这种故障表明本机有一条通向中心主机的路由,但没有收到发给该中心主机的任何信息。原因可能是:中心主机没有工作、本机或中心主机网络配置不正确、本地或中心的路由器没有工作、通信线路有故障、中心主机存在路由选择问题,等等。
(2)Request Timed Out:超时错误,被测试的机器不能正常连接,原因可能是该主机此时未连接(如已关机)、或到路由器的连接有问题、或路由器不能通过,或对方主机使用了防火墙软件禁止进行 Ping 测试等等。
(3)Unknown Host Name:无法解析主机名字,可能是DNS设置不对,或者对方主机不存在
telnet
telnet 经常可以确定远程服务的状态,比如确定远程服务器的某个端口是否能访问(端口连通性)。
telenet是windows标准服务,可以直接用;如果是linux或者mac,需要自己安装telnet
使用 telnet ip port
1)先用telnet连接不存在的端口
- [root@localhost ~]# telnet 10.0.250.3 80
- Trying 10.0.250.3...
telnet: connect to address 10.0.250.3: Connection refused #直接提示连接被拒绝
2)再连接存在的端口
- [root@localhost ~]# telnet localhost 22
- Trying ::1...
- Connected to localhost. #看到Connected就连接成功了
- Escape character is '^]'.
- SSH-2.0-OpenSSH_5.3
- a
- Protocol mismatch.
- Connection closed by foreign host.
总结
优秀和常用的 shell 命令有好多,我这里只写了几个非常常用,并且前端开发者也会经常用到的命令,希望对小伙伴们有一丢丢帮助。
当前标题:整理几个超实用的前端提效shell命令
本文路径:http://www.shufengxianlan.com/qtweb/news8/517858.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联