主頁 > 前端設計 > 南京郵電大學網路資訊安全——OpenSSL加密資料實驗(實驗二)

南京郵電大學網路資訊安全——OpenSSL加密資料實驗(實驗二)

2020-09-22 07:25:48 前端設計

南京郵電大學網路資訊安全——OpenSSL加密資料實驗(實驗二)

  • OpenSSL的下載和編譯
    • OpenSSL的下載
    • OpenSSL的編譯
      • 解壓
      • 配置
      • 編譯
  • 利用OpenSSL編程
    • 編譯測驗檔案
      • 測驗檔案是否通過
        • 設定環境變數(如果按照實驗指南來進行安裝,不需要設定環境變數)
    • 加密測驗
      • 原始碼撰寫
      • 編譯和測驗
  • 利用Openssl進行加密
    • 實驗內容一:利用AES進行加密
      • Base64編碼部分
      • 不同的加密方式
    • 實驗內容二:修改密文測驗
    • 實驗內容三:RSA公鑰和私鑰的生產
    • 實驗內容四:數字簽名
  • 總結

OpenSSL的下載和編譯

OpenSSL的下載

OpenSSL的下載鏈接為http://www.openssl.org/source/,在這里找到對應的下載方式
在這里插入圖片描述需要注意的是這里可能要搭個梯子,不然下載的可能會相當慢,當然也可以在國內找鏡像也不是不可以,
需要注意的是下載的時候要找對版本,i386對應IA32架構(32位系統),amd64對應x86-64架構(64位系統)
這里說一點題外話就是amd64即x86-64架構(俗稱的64位架構),由于該架構由amd提出并有inter發揚光大,所以有兩個稱呼,

OpenSSL的編譯

解壓

直接將下載好的內容放入Ubuntu即可,

在這里插入圖片描述然后執行一下解壓命令

user1@ubuntu:~/Desktop$ tar -xzvf openssl-3.0.0-alpha6.tar.gz

這里的xzvf引數的含義如下:

  • x:解壓tar格式的檔案
  • v:解壓時顯示詳細資訊
  • z:使用gzip程式解壓
  • f:使用歸檔

配置

解壓完成后檢查檔案夾
在這里插入圖片描述在檔案夾內運行

user1@ubuntu:~/Desktop/openssl-3.0.0-alpha6$ ./Configure 

這里和原本的實驗要輸入的指令不太一樣,原來的指令為:

./config –prefix=/usr/local

這里說一下,-perfix引數的意思是將軟體的安裝路徑指定一下,我這里選擇尊重Ubuntu的規范,不去修改他,同時寫一下安裝路徑的默認規劃為

檔案型別路徑
二進制檔案usr\local\bin
組態檔usr\local\etc
庫檔案usr\local\local

編譯

在原來的檔案夾里面運行make指令

user1@ubuntu: make & make install

這時螢屏上會出現大量的輸出
在這里插入圖片描述等待輸出完成,輸入指令

user1@ubuntu:  make test

可以看到正在進行測驗,
在這里插入圖片描述需要注意的是在進行測驗的程序中可能會出現某些錯誤,但是秉著夠用就好的原則,我們這里不去關注他,因為這些功能我們可能是用不到的,并且最后的測驗結果也是通過的,
在這里插入圖片描述然后執行命令,這個命令記得執行,不然找不到對應的頭檔案和動態庫…這個地方我debug了好久

make install

利用OpenSSL編程

編譯測驗檔案

測驗檔案原始碼如下

#include <stdio.h>
#include <evp.h>

int main()
{
printf("hello world!");
OpenSSL_add_all_algorithms();
return 0;
}

編譯

user1@ubuntu:~/Desktop/OpenSSL_Test$ gcc test.c -I /usr/local/include/openssl/    -lcrypto 

其中引數含義如下:

  • -I:頭檔案路徑
  • -lxxx:在鏈接階段鏈接動態庫libxxx.so,如這里鏈接libcrypto.so檔案

這里說一下如果直接按照實驗指南里面的指令(不完全一致,修改了環境變數)

gcc test.c –o test –I /usr/local/openssl/include /usr/local/libcrypto.a –ldl

會發現在鏈接階段無法通過
在這里插入圖片描述

測驗檔案是否通過

編譯完成后會出現以下的檔案
在這里插入圖片描述直接運行,會出現找不到動態庫的錯誤
在這里插入圖片描述原因在于Ubuntu的默認動態庫搜索路徑為/usr/lib,而我自定義的路徑為/usr/local/lib里面,所以需要設定以下環境變數,

設定環境變數(如果按照實驗指南來進行安裝,不需要設定環境變數)

打開元件組態檔

user1@ubuntu:~/Desktop/OpenSSL_Test$ sudo gedit /etc/ld.so.conf

添加自己的動態庫路徑
在這里插入圖片描述保存,并更新動態庫快取

sudo ldconfig

再次運行,即可成功
在這里插入圖片描述

加密測驗

原始碼撰寫

如果直接使用實驗指南里面的原始碼的話會出現以下報錯
在這里插入圖片描述經過查詢發現在Openssl更新到1.1版本后,其API有一點點改變,修改后的原始碼如下

#include <stdio.h>
#include <string.h>
#include <openssl/evp.h>
#include <openssl/x509.h> 
void tEVP_Encrypt()
{
	unsigned char key[EVP_MAX_KEY_LENGTH];//密鑰
	unsigned char iv[EVP_MAX_KEY_LENGTH];//初始化向量
	/* old usage*/
	//EVP_CIPHER_CTX ctx;//EVP演算法背景關系
	/* old usage*/

	/*new usage*/
	//EVP_CIPHER_CTX *ctx = EVP_CIPHER_CTX_new();
	/*new usage*/

	unsigned char out[1024];//輸出密文緩沖區
	int outl;//密文長度
	int outltmp;
	char *msg="Hello OpenSSL";//待加密的資料
	int rv;
	int i;	
	//設定key和iv(可以采用亂數和可以是用戶輸入)
	for(i=0;i<24;i++)
	{
		key[i]=i;
	}
	for(i=0;i<8;i++)
	{iv[i]=i;
	}//初始化密碼演算法結構體
	EVP_CIPHER_CTX_init(ctx);
	//設定演算法和密鑰以及向量
rv = EVP_EncryptInit_ex(ctx,EVP_des_ede3_cbc(),NULL,key,iv);
	if(rv!=1)
	{
		printf("Err\n");
		return;
	}
	//資料加密
	rv = EVP_EncryptUpdate(ctx,out,&outl,(const unsigned char*)msg,strlen(msg));
	if(rv!=1)
	{
		printf("Err\n");
		return;
	}//結束資料加密,把剩余資料輸出
	rv = EVP_EncryptFinal_ex(ctx,out+outl,&outltmp);
	if(rv!=1)
	{
		printf("Err\n");
		return;
	}
	outl = outl +outltmp;
	printf("Original text:%s\n",msg);
	//列印輸出密文
printf("Length of ciphertext:%d\n Data of ciphertext:\n",outl);
	for(i=0;i<outl;i++)
	{
		printf("0x%02x ",out[i]);
	}printf("\n");
}
int main()
{ 
	OpenSSL_add_all_algorithms();
	tEVP_Encrypt();
	return 0;
}

編譯和測驗

/usr/bin/g++ -g /home/user1/Desktop/OpenSSL_Test/test2.cpp -o /home/user1/Desktop/OpenSSL_Test/test2 -I /usr/local/include/openssl/ -lcrypto

執行即可成功

在這里插入圖片描述

利用Openssl進行加密

Openssl除了有編程介面外,還提供了命令列介面以便客戶使用

實驗內容一:利用AES進行加密

該實驗有兩個部分:

  1. 使用Base64和不使用Base64分別進行加密并觀察結果
  2. 采用不同模式進行加密

Base64編碼部分

首先說明一下Base64的作用,Base64基本上只做了一件事:將二進制資料編碼成了ASCII碼,以便于電子郵電閱讀,知道這點就夠了,
使用以下命令進行Base64加密

openssl enc -aes-256-cbc -salt -in lincoln.txt -out WithoutBase64.encn

其引數含義如下:

  • enc:加密
  • aes-256-cbc:采用aes演算法進行加密,256位密鑰,CBC模式
  • salt:加鹽
  • in:輸入檔案
  • out:輸出檔案
    對于加密完成的檔案,可以看到是一個二進制檔案,無法直接打開,
    在這里插入圖片描述利用二進制編輯軟體打開,可以看到,其是一堆二進制亂碼
    在這里插入圖片描述也就是無法直接通過電子郵件,qq聊天框直接傳遞的,

利用以下指令執行Base64編碼


openssl enc -aes-256-cbc -salt -a -in lincoln.txt -out WithBase64.encn

其中-a表示將密文用base64進行編碼,加密結果如下,可以看到,這次就是可讀文本了
在這里插入圖片描述

不同的加密方式

為了方便起見,我這里都對密文采用了Base64編碼,
首先采用CBC分組鏈接模式加密:

openssl enc -aes-256-cbc -salt -a -in lincoln.txt -out WithBase64CBC.encn

加密密文如下
在這里插入圖片描述


EBC密碼本加密模式進行加密

openssl enc -aes-256-ebc -salt -a -in lincoln.txt -out WithBase64EBC.encn

密文如下:
在這里插入圖片描述

實驗內容二:修改密文測驗

我修改了密文檔案,無論是修改還是增刪都會出現報錯
在這里插入圖片描述應該是OpenSSL的差錯控制的報錯吧,但也可能是我做的不太對…

實驗內容三:RSA公鑰和私鑰的生產

OpenSSL的公私鑰的生產分兩個步驟:

  1. 生成私鑰
openssl genrsa -out private.key
  1. 利用私鑰生成公鑰
openssl rsa -pubout -in private.txt -out public.txt

生成的私鑰如下:

-----BEGIN PRIVATE KEY-----
MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQC49ZkZxQwo3ewJ
RHNco+9hfAeoxEZfoG4wGtznGInMYqGdivzhjCK3tBDWdl8bwiJUp6JqoRIeySwb
0xuG4KQMQ5uOtigrCPZ+Wcj5fs/Gve9tMLrT0xVtXltIdRCFuiXKPMJ9ava3oy7Q
cpEIBAhUneN/O+PLirZMmKODx9x46lKCab6T19VQM7f+dWi2aHsFqmQkccaaPSE3
nquRpF6bSggJh2US/v88tCUs7Z+VKpsoCEVumFXF28Nuq8VnLJddfO7KitRS4XWs
VdVNjwjWr2FRL/YzIayYDbJ614azr0uEyoEbT/NtW2AKYJMnqvNbybc55JSDOcLv
k6RVZ1HtAgMBAAECggEAOIjZg0b3sIYk37BMksSJJwMCVFOqLxCanZmYbArUE+US
AVW6djafZgdkHimQaKuuUrHqsy0InOBg2yBsCY4glp8TrUuAe6cBsR1AkQJyAA2O
YZHDiXu70PJGdJ9TrYx4gJiR2kQXpYn7hTt/mTOiWDrqjrl/p3d+wWrmkCFHAq4X
qpMuiBYIJNcKQa+LgUq71rHchjsNeDmKRdjId+4zBYWygcxoRL/p4cfhs7sWpk5n
5beGanFYhauTRxQzrsfsePQP3PLQSJljkXVhIFC0mASORR0WnYw3j3n6599scmRN
w6lpAU7JnTtXk3vS8CA7kXABCYAuhYHq9jSlOMgfAQKBgQDp8a0PRnj/qGiGDELk
e+PzbKArOHfCnGQJD+N0Kwd0t0jByJ4TY1poBwKSGP95o2byYQfSnssckiPkVeiH
VMY7EuYD5PzoTGdkUpIBfyOhlqABAd99x2AUPgR7/a689rZb+ewV6s+dw0/avSqs
K/c2uqGu97wx+hyAh0EnurtiMwKBgQDKZai8Cj66uwZMntoEA29NGa7IJ2Gi0zpk
OhhF6MblI+TABgl/RM21Cob/6dmRerJNU0cKgWOtdRjhuJCZozkHOC4dY3m268WR
NkbchqBMjqpJSQj1oHlZ1opOl9AyM1pDRkdbGoXrl/zxEuRwpStokeCjvaTObK/c
RZEdJfObXwKBgGTL0UHMnmOg3vAqpkOlsZB3VAdrPAZotZ1F8D1kMME0GzALTTiT
TSeXJZ9nD+QL6FY0QleYPXEg8j/2V8q/Vu2q9dnltqYsDTwna2sjqWl86ZGlifK6
jYYLNolpwvj935J/ex3yXuPdfDGF4bXu94PoI7OsX7S0y8UBAaypgwULAoGAGdog
UlxwpMNMy66ipE6YAd4c8B3vn6+hTroI7a0M8qnCBzD+N45fRBejJL8G9kkYyz2u
3k2moLpLQlGjzqwFlcF8Sm6xVkcJRkILjRF5Gi5C2/eDOHSV6362zdEgW7kpd1xb
suxRXMVeHqDOIwFF6SZw7hlEGsXRNK6CGZoGYrsCgYEAmQXSYcSU2WCF28fxFzNX
IB8G56o3iCPMUsdxkWeIVPRURjpY5QJ8G4r6LDZyltyRIcNEF3Ak/NiJL//LWbPQ
44KxH2KeIcOcTF6Nr65u8YFLHtUj4AUSgdjN4+jicxk2cOhwXzogpOKf4tRePYrc
mwi8n7PJhj2bgzoaxwULXnQ=
-----END PRIVATE KEY-----

公鑰如下:

MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuPWZGcUMKN3sCURzXKPv
YXwHqMRGX6BuMBrc5xiJzGKhnYr84Ywit7QQ1nZfG8IiVKeiaqESHsksG9MbhuCk
DEObjrYoKwj2flnI+X7Pxr3vbTC609MVbV5bSHUQhbolyjzCfWr2t6Mu0HKRCAQI
VJ3jfzvjy4q2TJijg8fceOpSgmm+k9fVUDO3/nVotmh7BapkJHHGmj0hN56rkaRe
m0oICYdlEv7/PLQlLO2flSqbKAhFbphVxdvDbqvFZyyXXXzuyorUUuF1rFXVTY8I
1q9hUS/2MyGsmA2yeteGs69LhMqBG0/zbVtgCmCTJ6rzW8m3OeSUgznC75OkVWdR
7QIDAQAB
-----END PUBLIC KEY-----

在RSA演算法里面,鑰匙長度越長,消耗資源越多,對于一個數字簽名來說,私鑰只需要用一次,而公鑰需要使用多次,所以從總體角度來說,私鑰要比公鑰長的多,

實驗內容四:數字簽名

使用以下指令進行數字簽名
回顧以下數字簽名的程序:首先進行Hash處理,后對Hash值進行簽名

openssl dgst -sha1 -sign private.txt   -out mytest.dig mytest

引數:

  • dgst:digest,數字簽名
  • sha1:采用sha1進行hash
  • sign:簽名鑰匙

需要指出的是簽名為二進制序列,所以無法正常打開,并且Openssl在簽名工具里面也沒有提供Base64轉碼工具,以下是我的數字簽名

在這里插入圖片描述


驗證簽名采用如下指令

openssl dgst -sha1 -verify pubkey.pem -signature B13040450.sha1 B13040450

驗證成功:
在這里插入圖片描述

總結

總體來說,這次的實驗雖然涉及到了Ubuntu下的編譯和編程,但是可能由于openssl用的人比較多,編譯程序中并沒有“煉丹“,并且測驗原始碼都已經給出了,所以總體來說比較簡單,相較第一個實驗來說,因為并沒有涉及到軟體的使用,所以并沒有像使用WireShark時由于每個人的WireShark版本不一致導致實驗難易不一,
需要注意的有兩個點:

  • 動態庫名稱及路徑的設定,在這個實驗里面要鏈接的動態庫為libcrypto.so
  • Openssl的API的變化

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/102905.html

標籤:其他

上一篇:阿里云ECS高校計劃預備營技能自測

下一篇:2020年云南省專升本考試辦法(專升本政策)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more