学习目标
HTTP 协议的全称是(HyperText Transfer Protocol),翻译过来就是超文本传输协议。
超文本是超级文本的缩写,是指超越文本限制或者超链接,比如:图片、音乐、视频、超链接等等都属于超文本。
HTTP 协议的制作者是蒂姆·伯纳斯-李,1991年设计出来的,HTTP 协议设计之前目的是传输网页数据的,现在允许传输任意类型的数据。
传输 HTTP 协议格式的数据是基于 TCP 传输协议的,发送数据之前需要先建立连接。
它规定了浏览器和 Web 服务器通信数据的格式,也就是说浏览器和web服务器通信需要使用http协议。
通信效果图:
学习目标
URL的英文全拼是(Uniform Resoure Locator),表达的意思是统一资源定位符,通俗理解就是网络资源地址,也就是我们常说的网址。
URL的样子:
https://news.163.com/18/1122/10/E178J2O4000189FH.html
URL的组成部分:
域名:
域名就是IP地址的别名,它是用点进行分割使用英文字母和数字组成的名字,使用域名目的就是方便的记住某台主机IP地址。
URL的扩展:
https://news.163.com/hello.html?page=1&count=10
参数说明:
学习目标
首先需要安装Google Chrome浏览器,然后Windows和Linux平台按F12调出开发者工具, mac OS选择 视图 -> 开发者 -> 开发者工具或者直接使用 alt+command+i 这个快捷键,还有一个多平台通用的操作就是在网页右击选择检查。
开发者工具的效果图:
开发者工具的标签选项说明:
开发者工具使用效果图:
开发者工具的使用说明:
查看http请求信息效果图:
查看http响应信息效果图:
学习目标
HTTP最常见的请求报文有两种:
说明:
HTTP GET 请求报文效果图:
GET 请求报文说明:
---- 请求行 ----
GET / HTTP/1.1 # GET请求方式 请求资源路径 HTTP协议版本
---- 请求头 -----
Host: www.itcast.cn # 服务器的主机地址和端口号,默认是80
Connection: keep-alive # 和服务端保持长连接
Upgrade-Insecure-Requests: 1 # 让浏览器升级不安全请求,使用https请求
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36 # 用户代理,也就是客户端的名称
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8 # 可接受的数据类型
Accept-Encoding: gzip, deflate # 可接受的压缩格式
Accept-Language: zh-CN,zh;q=0.9 #可接受的语言
Cookie: pgv_pvi=1246921728; # 登录用户的身份标识
---- 空行 ----
GET 请求原始报文说明:
GET / HTTP/1.1\r\n
Host: www.itcast.cn\r\n
Connection: keep-alive\r\n
Upgrade-Insecure-Requests: 1\r\n
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36\r\n
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8\r\n
Accept-Encoding: gzip, deflate\r\n
Accept-Language: zh-CN,zh;q=0.9\r\n
Cookie: pgv_pvi=1246921728; \r\n
\r\n (请求头信息后面还有一个单独的’\r\n’不能省略)
说明:
HTTP POST 请求报文效果图:
请求体效果图:
POST 请求报文说明:
---- 请求行 ----
POST /xmweb?host=mail.itcast.cn&_t=1542884567319 HTTP/1.1 # POST请求方式 请求资源路径 HTTP协议版本
---- 请求头 ----
Host: mail.itcast.cn # 服务器的主机地址和端口号,默认是80
Connection: keep-alive # 和服务端保持长连接
Content-Type: application/x-www-form-urlencoded # 告诉服务端请求的数据类型
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36 # 客户端的名称
---- 空行 ----
---- 请求体 ----
username=hello&pass=hello # 请求参数
POST 请求原始报文说明:
POST /xmweb?host=mail.itcast.cn&_t=1542884567319 HTTP/1.1\r\n
Host: mail.itcast.cn\r\n
Connection: keep-alive\r\n
Content-Type: application/x-www-form-urlencoded\r\n
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36\r\n
\r\n(请求头信息后面还有一个单独的’\r\n’不能省略)
username=hello&pass=hello
说明:
GET和POST请求对比效果图:
学习目标
HTTP 响应报文效果图:
响应报文说明:
--- 响应行/状态行 ---
HTTP/1.1 200 OK # HTTP协议版本 状态码 状态描述
--- 响应头 ---
Server: Tengine # 服务器名称
Content-Type: text/html; charset=UTF-8 # 内容类型
Transfer-Encoding: chunked # 发送给客户端内容不确定内容长度,发送结束的标记是0\r\n, Content-Length表示服务端确定发送给客户端的内容大小,但是二者只能用其一。
Connection: keep-alive # 和客户端保持长连接
Date: Fri, 23 Nov 2018 02:01:05 GMT # 服务端的响应时间
--- 空行 ---
--- 响应体 ---
<!DOCTYPE html><html lang=“en”> …</html> # 响应给客户端的数据
原始响应报文说明:
HTTP/1.1 200 OK\r\n
Server: Tengine\r\n
Content-Type: text/html; charset=UTF-8\r\n
Transfer-Encoding: chunked\r\n
Connection: keep-alive\r\n
Date: Fri, 23 Nov 2018 02:01:05 GMT\r\n
\r\n(响应头信息后面还有一个单独的’\r\n’不能省略)
<!DOCTYPE html><html lang=“en”> …</html>
说明:
每项数据之间使用:\r\n
HTTP 状态码是用于表示web服务器响应状态的3位数字代码。
状态码 | 说明 |
200 | 请求成功 |
307 | 重定向 |
400 | 错误的请求,请求地址或者参数有误 |
404 | 请求资源在服务器不存在 |
500 | 服务器内部源代码出现错误 |
学习目标
可以为发出请求的浏览器提供静态文档的程序。
平时我们浏览百度新闻数据的时候,每天的新闻数据都会发生变化,那访问的这个页面就是动态的,而我们开发的是静态的,页面的数据不会发生变化。
搭建Python自带的静态Web服务器使用 python3 -m http.server 端口号, 效果图如下:
-m选项说明:
-m表示运行包里面的模块,执行这个命令的时候,需要进入你自己指定静态文件的目录,然后通过浏览器就能访问对应的 html文件了,这样一个静态的web服务器就搭建好了。
通过浏览器访问搭建的静态Web服务器,效果图如下:
查看http的通信过程,效果图如下:
hp开发问题日志——selectpage 使用
最近修改fastadmin的selectpage,想用js动态修改选中值,查找文档,百度搜索都没有结果,有知道的大神可以留言,告诉我方法,不胜感谢。
在找解决方法时,看到一个属性searchField:查询关键字字段。fastadmin中,并没有这个属性,但是原生的有,我找了一下fastadmin的selectpage.js文件,搜索了词条searchField,找到这个地方
SelectPage.prototype.setOption=function (option) {
修改了里面的内容:
SelectPage.prototype.setOption=function (option) {
//use showField to default
//option.searchField=option.searchField || option.showField;
let search_field=option.searchfield || option.searchField || option.showField;
if(Array.isArray(search_field)){
var arr=['searchField'];
for (var i=0; i < arr.length; i++) {
option[arr[i]]=this.strToArray(option[arr[i]]);
}
}else{
option.searchField=search_field.split(',');
}
console.log(option);
option.andOr=option.andOr.toUpperCase();
if (option.andOr !=='AND' && option.andOr !=='OR') option.andOr='AND';
//support multiple field set
然后在view中html中添加了data-searchField="mobile,username,nickname",这样的效果就是可以输入一个关键词,用or搜索三个字段;html代码:
<input id="c-user_id" data-rule="required" data-source="user/user/index" data-params='{"custom[agent_type]":0}' data-field="username"
data-searchField="username,nickname,mobile" class="form-control selectpage" name="row[user_id]" type="text" value="">
控制器的selectpage方法的相关代码:
$logic=$andor=='AND' ? '&' : '|';
$searchfield=is_array($searchfield) ? implode($logic, $searchfield) : $searchfield;
$searchfield=str_replace(',', $logic, $searchfield);
$word=array_filter(array_unique($word));
if (count($word)==1) {
$query->where($searchfield, "like", "%" . reset($word) . "%");
} else {
$query->where(function ($query) use ($word, $searchfield) {
foreach ($word as $index=> $item) {
$query->whereOr(function ($query) use ($item, $searchfield) {
$query->where($searchfield, "like", "%{$item}%");
});
}
});
从控制器中的代码看,searchfield是可以为数组的;
参数传递的效果:
同时发送三个搜索字段
下是一个使用C# WinForms中的TabControl控件的简单示例:
using System;
using System.Drawing;
using System.Windows.Forms;
public class MainForm : Form
{
private TabControl tabControl;
private TabPage tabPage1;
private TabPage tabPage2;
private TextBox textBox1;
private TextBox textBox2;
public MainForm()
{
// 创建主窗体
Text="TabControl示例";
Size=new Size(400, 300);
// 创建TabControl控件
tabControl=new TabControl();
tabControl.Dock=DockStyle.Fill;
// 创建第一个选项卡页
tabPage1=new TabPage();
tabPage1.Text="选项卡1";
// 创建第一个选项卡页中的文本框
textBox1=new TextBox();
textBox1.Multiline=true;
textBox1.Dock=DockStyle.Fill;
textBox1.Text="选项卡1的内容";
// 将文本框添加到第一个选项卡页
tabPage1.Controls.Add(textBox1);
// 创建第二个选项卡页
tabPage2=new TabPage();
tabPage2.Text="选项卡2";
// 创建第二个选项卡页中的文本框
textBox2=new TextBox();
textBox2.Multiline=true;
textBox2.Dock=DockStyle.Fill;
textBox2.Text="选项卡2的内容";
// 将文本框添加到第二个选项卡页
tabPage2.Controls.Add(textBox2);
// 将选项卡页添加到TabControl控件
tabControl.TabPages.Add(tabPage1);
tabControl.TabPages.Add(tabPage2);
// 将TabControl控件添加到主窗体
Controls.Add(tabControl);
}
[STAThread]
static void Main()
{
Application.Run(new MainForm());
}
}
在示例中,创建了一个名为MainForm的主窗体,并在窗体上添加了一个名为tabControl的TabControl控件。还创建了两个选项卡页tabPage1和tabPage2,并将它们分别添加到TabControl控件中。
在每个选项卡页中创建了一个文本框textBox1和textBox2,并将它们分别添加到对应的选项卡页中。
最后,将TabControl控件添加到主窗体的控件集合中。
运行此示例,您将看到一个具有TabControl控件和两个选项卡页的窗体。您可以切换选项卡来显示不同的内容。
*请认真填写需求信息,我们会在24小时内与您取得联系。