当前位置: 首页 > 编程日记 > 正文

linux下的usb抓包方法【转】

转自:http://blog.chinaunix.net/uid-11848011-id-4508834.html

1、配置内核使能usb monitor:

make menuconfig
                   Device Drivers -->
                            USB Support -->
                                     USB Monitor --> Select * not M
2、build kernel
    sudo insmod /lib/modules/3.2.1/kernel/drivers/usb/mon/usbmon.ko


3、启动内核后执行
                   #mount -t debugfs none_debugs /sys/kernel/debug
                   
                   检查是否存在目录 /sys/kernel/debug/usb/usbmon
                   #ls /sys/kernel/debug/usb/usbmon

0s  0u  1s  1t  1u  2s  2t  2u  3s  3t  3u
                 
                  # cat /sys/kernel/debug/usb/devices 确定你要监视的usb设备所在总线号和设备号
                   #       选择包含有 : Vendor=148f ProdID=5370 Rev= 1.01 的段落
                   #       as follows:
                   #                T:  Bus=01Lev=01 Prnt=01 Port=00 Cnt=01 Dev#=  2 Spd=480  MxCh= 0
                   #                D:  Ver= 2.00 Cls=00(>ifc ) Sub=00 Prot=00 MxPS=64 #Cfgs=  1
                   #                P:  Vendor=148f ProdID=5370 Rev= 1.01
                   #                S:  Manufacturer=Ralink
                   #                S:  Product=802.11 n WLAN
                   #                S:  SerialNumber=1.0
                   #                C:* #Ifs= 1 Cfg#= 1 Atr=80 MxPwr=450mA
                   #                I:* If#= 0 Alt= 0 #EPs= 5 Cls=ff(vend.) Sub=ff Prot=ff Driver=rtusbSTA
                   #                E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
                   #                E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
                   #                E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
                   #                E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
                  #                E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
                   #       可以从第一行看到 Bus= 01,设备号是2

4、保存 usb raw packet ,如果总线号是1,则是1u,如果总线号是2,则是2u,依次类推。特殊情况是0u表示监听所有总线
                   if (Bus == 01)
                            sudo cat /sys/kernel/debug/usb/usbmon/1u > ./rt5370-UsbMon.txt
                   else if (Bus == 02)
                            sudo cat /sys/kernel/debug/usb/usbmon/2u > ./rt5370-UsbMon.txt

2 抓的usb包的格式解析

The usbmon reports requests made by peripheral-specific drivers to Host
Controller Drivers (HCD). So, if HCD is buggy, the traces reported by
usbmon may not correspond to bus transactions precisely. This is the same
situation as with tcpdump.

上面的基本说明了usbmon主要的工作原理,他会把usb host drivers发送到hcd的所有请求(usb_submit_urb)和请求的回调内容(即改请求对应的回调函数:urb->complete)都报告出来。


Any text format data consists of a stream of events, such asURB submission(S),
URB callback(C), submission error(E). Every event is a text line, which consists
of whitespace separated words. The number or position of words may depend
on the event type, but there is a set of words, common for all types.
所以这里的URB submission即是对应usb host drivers中的usb_submit_urb(urb, mem_flags)
而URB callback即使对应urb的回掉函数:urb->complete
所以我们会看到even type为S的和紧邻的event type为C的事件,他们对应的URB tag都是一样的
因为他们都是针对同一个URB而言的。
先给出三个列子:
eea76f80 3474782286 S Ii:1:003:3 -115:128 16 <
edda2b80 3474786256 C Ii:1:006:1 0:1 16 = 2fff0180 d6ef206e 1401020c 015aab73
e11c9280 3500399358 S Co:1:006:0 s 20 00 0000 0000 0007 7 = 370c0447 00401f
e11c9280 3500399866 C Co:1:006:0 0 7 >

Here is the list of words, from left to right:


- URB Tag. This is used to identify URBs, and is normally an in-kernel address
  of the URB structure in hexadecimal, but can be a sequence number or any
  other unique string, within reason.
一般就是在usb host driver中分配的urb的内核地址,一般通过如下函数来分配:

urb = usb_alloc_urb(0, mem_flags);

由于一个urb对应一个端口,所以同一个端口他们的urb tag都是一样的。
002e2002999116296 C Ci:1:008:0 0 4 = 8d2b0000

 Timestampin microseconds, a decimal number. The timestamp's resolution
  depends on available clock, and so it can be much worse than a microsecond
  (if the implementation uses jiffies, for example).
e002e200 2999116296Ci:1:008:0 0 4 = 8d2b0000

注意单位是微秒。

Event Type. This type refers to the format of the event, not URB type.
  Available types are:S - submission, C - callback, E - submission error.
e002e200 2999116296 C Ci:1:008:0 0 4 = 8d2b0000

表示的意思是:usb host drivers通过usb_submit_urb函数向linuxusb core提交了一个urb传输请求,我们知道所有的usb传输,都是host端主动发起的,所以必须要有host drivers主动发出submit urb的动作

- "Address" word (formerly a "pipe"). It consists of four fields, separated by
  colons: URB type and direction, Bus number, Device address, Endpoint number.
  Type and direction are encoded with two bytes in the following manner:
    Ci Co   Control input and output
    Zi Zo   Isochronous input and output
    Ii Io   Interrupt input and output
    Bi Bo   Bulk input and output
  Bus number, Device address, and Endpoint are decimal numbers, but they may
  have leading zeros, for the sake of human readers.

所以地址字段的格式是如下:

URB type and direction:Bus number:Device address:Endpoint number

如下列子:
e002e200 2999116296 C Ci:1:008:0 0 4 = 8d2b0000

意思是:控制传输输入,总线号为1,设备地址为008,由于所有的控制传输都是在endpoint 0上的,所以最后的端口自然也是0了。

这里需要注意,由于我们的这个抓包命令,只能指定是抓哪个总线上,但同一个总线通常会有很多usb设备的,如果我们只是关注特定的某个usb设备的话,我自己就需要留意设备地址字段,通过这个字段,我们就可以区分这个传输是不是我们要监听的设备发送出来的。

例如下面一段usb sniffer log:

edda2b80 3500379613 C Ii:1:006:1 0:1 8 = 0e06010d 08004700
edda2b80 3500394156 S Ii:1:006:1-115:1 16 <
eea76f80 3500394226 C Ii:1:003:3 0:128 16 = a12a0000 01000800 00e1f505 00e1f505
eea76f80 3500394236 S Ii:1:003:3 -115:128 16 <

同样都是usb总线1下面的,由于一个usb总线就对应一个usb host controller,但一个设备地址是006,另一个则是003,前者对应的是usb bluetooth dongle的中断传输,而后者则是usb鼠标的中断传输,他们接在同一个总线的usb hub下面。我们真正需要监听只是usb bluetooth dongle,所以就可以不受usb鼠标的干扰。

- URB Status word. This is either a letter, or several numbers separated
  by colons: URB status, interval, start frame, and error count. Unlike the
  "address" word, all fields save the status are optional. Interval is printed
  only for interrupt and isochronous URBs. Start frame is printed only for
  isochronous URBs. Error count is printed only for isochronous callback
  events.
这里的意思就是,urb的状态字,有两种可能,一种是“字母”;一种是“数字”,如果是前者则一般就是字母“s”,表示一个控制传输,而如果是数字,他们的格式则分两种情况:

如果是中断传输,格式如下:   URB status:interval,注意状态字段只对C类型的事件有意义,对S类型的事件没有意思。

如果是同步传输,格式如下:URB status:interval:{start frame}:{error count}

The status field is a decimal number, sometimes negative, which represents
  a "status" field of the URB. This field makes no sense for submissions, but
  is present anyway to help scripts with parsing. When an error occurs, the
  field contains the error code.
e002e200 2999116296 C Ci:1:008:0 0 4 = 8d2b0000

状态域:status就是struct urb结构体中的status字段,该字段直接说明当前的usb请求是否成功执行。所以只有在回调的时候才有意思。

In case of a submission of a Control packet, this field contains a Setup Tag
  instead of an group of numbers. It is easy to tell whether the Setup Tag is
  present because it is never a number. Thus if scripts find a set of numbers
  in this word, they proceed to read Data Length (except for isochronous URBs).
  If they find something else, like a letter, they read the setup packet before
  reading the Data Length or isochronous descriptors.
e002e200 2999116113 S Ci:1:008:0 s c0 07 0000 1134 0004 4 <

字母“s”是控制传输的标志

Setup packet, if present, consists of 5 words: one of each for bmRequestType,
  bRequest, wValue, wIndex, wLength, as specified by the USB Specification 2.0.
  These words are safe to decode if Setup Tag was 's'. Otherwise, the setup
  packet was present, but not captured, and the fields contain filler.

即控制传输包的格式如下:

bmRequestType(请求类型):bRequest(请求号):wValue:wIndex(下标):wLength(数据字段的长度,如果为0,说明没有数据段)

e11c9280 3500399358 S Co:1:006:0 s20 00 0000 0000 0007 7 =370c0447 00401f
e11c9280 3500399866 C Co:1:006:0 0 7 > //表示上面的控制传输请求成功,并且实际传输了7个btye的数据,仅表示状态,不对应具体的控制传输阶段
20 00 0000 0000 0007对应控制传输的setup阶段,370c0447 00401f对应控制传输的数据阶段(OUT传输),数据长度是7个字节

- Number of isochronous frame descriptors and descriptors themselves.
  If an Isochronous transfer event has a set of descriptors, a total number
  of them in an URB is printed first, then a word per descriptor, up to a
  total of 5. The word consists of 3 colon-separated decimal numbers for
  status, offset, and length respectively. For submissions, initial length
  is reported. For callbacks, actual length is reported.


Data Length. For submissions, this is the requested length. For callbacks,
  this is the actual length.
e002e200 2999116296 C Ci:1:008:0 04 = 8d2b0000
又如下:
edda2b80 3500272851 S Ii:1:006:1 -115:116 <
edda2b80 3500273622 C Ii:1:006:1 0:1 7 = 13050147 000100
第一句是发起一个请求长度为16字节的usb中断传输请求,该字段一般在端点描述符中会说明该管道所支持的最大数据包大小
第二句是该中断传输请求实际返回的数据则只有7个字节,即对应urb->actual_length字段
以上两句对应一个 中断IN传输

Data tag. The usbmon may not always capture data, even if length is nonzero.
  The data words are present only if this tag is '='.
e002e200 2999116296 C Ci:1:008:0 0 4 =8d2b0000
data tag就是“=”,表示有数据段,“=”号后面就是具体的数据内容

Data words follow, in big endian hexadecimal format. Notice that they are
  not machine words, but really just a byte stream split into words to make
  it easier to read. Thus, the last word may contain from one to four bytes.
  The length of collected data is limited and can be less than the data length
  reported in the Data Length word. In the case of an Isochronous input (Zi)
  completion where the received data is sparse in the buffer, the length of
  the collected data can be greater than the Data Length value (because Data
  Length counts only the bytes that were received whereas the Data words
  contain the entire transfer buffer).
e002e200 2999116296 C Ci:1:008:0 0 4 = 8d2b0000

Examples:
An input control transfer to get a port status.
d5ea89a0 3575914555 S Ci:1:001:0 s a3 00 0000 0003 00044<
a3 00 0000 0003 0004”对应控制传输的setup阶段,“4”对应控制传输的数据阶段长度
5ea89a0 3575914560 C Ci:1:001:0 0 4 = 01050000
对应控制传输的数据阶段的data IN传输,”01050000“即为数据 ,为4byte长度

An output bulk transfer to send a SCSI command 0x28 (READ_10) in a 31-byte
Bulk wrapper to a storage device at address 5:

dd65f0e8 4128379752 S Bo:1:005:2 -115 31 = 55534243 ad000000 00800000 80010a28 20000000 20000040 00000000 000000
dd65f0e8 4128379808 C Bo:1:005:2 0 31 > //指示这个bulk传输请求时成功的,并且实际也传输了31个byte的数据。


3 USB Sniffing with tcpdump

usbmon is a facility in kernel which is used to collect traces of I/O on the USB bus. usbmon collects raw text/binary which are not easily human-readable. Here, the idea is to use Wireshark as frontend to produces a human-readable representation of these data. However Wireshark does not support usbmon raw data as is, so we have to parse these data in the pcap format. tcpdump is a good candidate to capture USB data from usbmon and generate pcap traces

前提条件,是需要最新的tcpdump工具才行,有编译好的,可以直接download下来push到板子上就可以使用。也有可以自己手动来编译的。这里就不详细来说了。

步骤:

  • mount -t debugfs none_debugs /sys/kernel/debug
  • cat /sys/kernel/debug/usb/devices 确定usb的总线号
  • tcpdump -D

1.eth0
2.usbmon1 (USB bus number 1)
3.usbmon2 (USB bus number 2)
4.usbmon3 (USB bus number 3)
5.any (Pseudo-device that captures on all interfaces)
6.lo

有以上红色部分输出,说明你的tcpdump已经安装下,可以正常使用

  • tcpdump -i usbmon1 -w /data/usblog.pcap &
  • killall tcpdump
  • wireshark usblog.pcap //最好使用wireshark工具查看就可以了

上个图参考下,打开后是什么样子:

参考文档:
W:\wm8880\android\ANDROID_3.4.5\trunk\Documentation\usb\usbmon.txt
http://omappedia.org/wiki/USB_Sniffing_with_tcpdump










本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/sky-heaven/p/5071348.html,如需转载请自行联系原作者


相关文章:

中小学AI教育靠谱吗?50%教师教学经验不足1年

作者 | 琥珀出品 | AI科技大本营&#xff08;rgznai100&#xff09;近日&#xff0c;一份《中小学阶段人工智能普及教育现状调研报告》的发布让我们不禁汗颜当下中国中小学人工智能教育普及程度、教师教育水平所存在的问题。链接&#xff1a;http://www.cacsi.org.cn/Uploads/a…

你,保持童心;我,帮你保持童颜

在周星驰的《美人鱼》里有这样一句&#xff1a; 童话是存在的&#xff0c;只不过不是幻想的&#xff0c;而是自己去搭建的儿童节到了 感觉自己又小了一岁 越来越年轻了呢&#xff01; 望遍朋友圈&#xff0c; 都是一群该当妈的在过六一 大龄儿童这么凑热闹是不是不太好呢&#…

java程序通过命令行运行之Path和ClassPath的注意点

习惯用IDE的朋友可能早就不用cmd&#xff0c;想当初我们刚学java的时候还记得对着黑屏幕敲的&#xff0c;哈哈。让我们再来重温旧梦。 我们在现在有这样一个文件HelloWorld.java&#xff0c;它的路径是这样的E:\javaTest\HelloWorld.java public class HelloWorld { public…

美通信与动力公司向WIN-T军事通信计划提供支持

美通信与动力公司向WIN-T军事通信计划提供支持[据美国军事与航宇电子网2009年2月17日报道]日前&#xff0c;通信与动力工业公司&#xff08;CPI&#xff09;从通用动力卫星通信技术公司获得一项价值大约为1300万美元的后续合同&#xff0c;向美国陆军士兵信息网络战术&#xff…

看动画轻松理解“递归”与“动态规划”

作者 | 程序员小吴来源 | 五分钟学算法在学习「数据结构和算法」的过程中&#xff0c;因为人习惯了平铺直叙的思维方式&#xff0c;所以「递归」与「动态规划」这种带循环概念&#xff08;绕来绕去&#xff09;的往往是相对比较难以理解的两个抽象知识点。程序员小吴打算使用动…

毕业季:理想很丰满,现实也可以很丰满!

六月&#xff0c;原本不是一个适合离开的季节&#xff0c;不是烈日&#xff0c;就是暴雨&#xff0c;让人不得不走走停停&#xff0c;频频回望。然而&#xff0c;哪个季节又适合离开呢&#xff1f;六月&#xff0c;确实得离开了。大学几年的时光终将逝去&#xff0c;而之后各位…

php扩展模块安装-lamp

php扩展模块安装 PECL 的全称是 The PHP Extension Community Library &#xff0c;是一个开放的并通过 PEAR(PHP Extension and Application Repository&#xff0c;PHP 扩展和应用仓库)打包格式来打包安装的 PHP扩展库仓库。通过 PEAR 的 Package Manager 的安装管理方式&…

一文搞懂K近邻算法(KNN),附带多个实现案例

简介&#xff1a;本文作者为 CSDN 博客作者董安勇&#xff0c;江苏泰州人&#xff0c;现就读于昆明理工大学电子与通信工程专业硕士&#xff0c;目前主要学习机器学习&#xff0c;深度学习以及大数据&#xff0c;主要使用python、Java编程语言。平时喜欢看书&#xff0c;打篮球…

致那些还在创业之路上孤独前行的青年大学生们!

彩虹&#xff0c;在大雨后出现 腊梅&#xff0c;在风雪中吐蕊 雄鹰&#xff0c;在险峰上空盘旋 人&#xff0c;在困境中弥坚 在这个创业的浪潮中 你是否也是其中之一 当所有事情都将有你一个人来完成 你是否有信心和能力把它做好 成功不是回首&#xff0c;不是寄望&#xff0c;…

MS DTC 无法正确处理 DC 升级/降级事件的解决

当Windows 2003安装AD后&#xff0c;经常出现以下警告信息的解决方法&#xff1a;MS DTC 无法正确处理 DC 升级/降级事件。MS DTC 将继续运行并将使用现有的安全设置。错误说明: %1, 打开管理工具的组件服务管理控制台&#xff0c;打开组件服务&#xff0c;计算机。右击我的电…

UML图的分类

作为一种建模语言,UML的定义包括UML语义和UML表示法两个部分。 (1) UML语义 描述基于UML的精确元模型定义。元模型为UML的所有元素在语法和语义上提供了简单、一致、通用的定义性说明,使开发者能在语义上取得一致,消除了因人而异的最佳表达方法所造成的影响。此外UML还支持对元…

告诫那些有创业梦的大学生,切记千万不要盲目创业!

如果你打算创业&#xff0c;那么最好具备两点&#xff1a; 一是有一定的经济实力或行业经验和人脉&#xff0c; 二是没有太多后顾之忧。 有一部分创业者是前期赚了一些钱&#xff0c;能确保基本生活的质量&#xff01;所以可以全身心投入到创业中&#xff0c;提高成功的概率。然…

春运渡劫!Python给我抢回家的火车票

简介&#xff1a;本文首发于个人公众号「视学算法」&#xff0c;作者阿广&#xff0c;一个专注于大数据、人工智能和算法的学习平台&#xff0c;也是一个保送中科院软件研究所直博生的自留地。人生苦短&#xff0c;我愿做您最忠实的技术支持伙伴&#xff01;一起用代码改变世界…

首次成功实施 XSS 攻击,盗取目标网站大量 VIP 帐号

前言 之前做网站时有做代码防御 XSS(Cross Site Script) 攻击&#xff0c;但是却只处于了解的阶段&#xff0c;并不知道其中具体的原理&#xff0c;更别说使用了。最近有朋友要求我帮助他 Hack 一个网站&#xff0c;达到一定的目的。思考来思考去&#xff0c;最后想了一套方案&…

oracle取得表中总记录数最快的方法

查询表中的记录总数的语法就是SELECT COUNT(*) FROM TABLE_NAME。这可能是最经常使用的一类SQL语句。 本文讨论怎样才能最快的得到这个记录数。本文纯粹主要是理论上的讨论&#xff0c;文章中很多内容&#xff08;如常数索引&#xff09;对实际的指导意义不大。 在具体描述之前…

你的创业前行之路,亲君愿与你一路相随

每一个创业者都是黑暗中的独行侠&#xff0c; 然后告诉别人光明就在前方&#xff0c; 其实&#xff0c; 他们自己心里也不知道光明还有多远。 无论当初是因为理想还是因为实现个人价值&#xff0c; 只要走上创业这条路&#xff0c; 我们就只能不断的告诉自己和他人&#xff1a;…

年度重磅:《AI聚变:2018年优秀AI应用案例TOP 20》正式发布

2018 年&#xff0c;AI 行业的关键词或许非“落地”二字莫属 &#xff0c;人们强烈期待着更多 AI 技术应用和深入商业化。 一方面&#xff0c;科技巨头们在横向铺设 AI 技术平台&#xff0c;但也更强调 AI 与每一个垂直行业的深度融合。而另一面&#xff0c;AI 创业公司在频繁刷…

防止熊猫烧香的微软补丁

为了防止熊猫烧香病毒,要及时安装微软的安全更新&#xff0c;不要随意访问来源不明的网站。特别是微软的MS06-014漏洞&#xff0c;应立即打好该漏洞补丁。 不知道这个补丁是不是已经打上的朋友,一是在控制面板里可以看到.(勾上显示更新前面的方框),或者下载360安全卫士,扫描漏洞…

【Azure Services Platform Step by Step-第11篇】Windows Azure兰州拉面馆-日志与队列的使用...

在第9篇里&#xff0c;为了便于大家理解&#xff0c;我把Windows Azure的环境比喻成了"Azure兰州拉面馆"。本篇我们继续沿用这个比喻&#xff0c;讲讲Windows Azure中的队列(Queue Storage)与日志的使用。 Queue Storage在【Azure Services Platform Step by Step-第…

这才是世界排名前十位的奢侈品

​​真正的奢侈品&#xff0c;不是豪车大宅&#xff0c;不是名包贵表&#xff0c;而是这些…… 1. 一颗童心2. 生生不息的信念3. 背包走天下的健康体魄4. 愉悦和舒心的工作环境5. 安稳平和的睡眠6. 享受属于自己空间与时间的生活7. 牵手一个教会你爱与被爱的人8. 品味美好的心情…

配置springmvc在其他类中(spring容器外)获取注入bean

今天在写JedisUtils的时候要注入JedisPool&#xff0c;而这个属性被设置为static&#xff0c;Resource和Autowired都不可以注入&#xff0c;因为spring不能为静态变量依赖注入。因此需要额外的方法获取spring管理的bean。本文即SpringContextHolder&#xff1a; 1 package com.…

声智科技完成2亿元B轮融资,将持续拓展语音交互产品的规模化落地

整理 | 一一出品 | AI科技大本营寒冬之下&#xff0c;不少创业公司依然得到了资本青睐。AI科技大本营消息&#xff0c;12 月 29 日消息&#xff0c;声智科技&#xff08;SoundAI&#xff09;已于近期完成 2 亿人民币 B 轮融资&#xff0c;本轮投资由毅达资本领投&#xff0c;峰…

360度看IT行业--3月12日西安工程大学讲座

2009年3月12日&#xff0c;一个绿色的好日子。当天晚上7点30分&#xff0c;在西安工程大学的讲座开始了。西安工程大学的孩子们很热情&#xff0c;大一大二的居多&#xff0c;虽然是非计算机专业&#xff0c;但提前就满满的坐在会场等待了。而且很关注IT行业&#xff0c;提了很…

专访中国移动钱岭:大数据更像是一种“倍增器”

记者 | 杨丽出品 | AI科技大本营&#xff08;rgznai100)为把握时代特征&#xff0c;2016 年中国移动确定并大力推动“大连接”战略&#xff0c;并制定了“十三五”时期做大连接规模、做优连接服务、做强连接应用的三个目标。如今&#xff0c;这家企业已经拥有 9.16 亿移动端用户…

创业者应该如何看待金钱

什么是真正的赢&#xff1f;一个高智商、高情商的商人&#xff0c;经营企业追求的终极目标就是一个赢字&#xff1a;金钱、地位、豪宅、名车、美女、权利、荣耀&#xff0c;为了赢得这些&#xff0c;很多人曾不择手段&#xff0c;曾不断地苦苦寻找“如何以最小的投入快速获得最…

Exchange与ADFS单点登录 PART 2:部署和配置ADFS

在第一篇文章完了之后&#xff0c;我们就可以在我们的服务器上部署ADFS了&#xff0c;安装的方法很简单&#xff0c;直接在服务器管理器中添加功能角色即可&#xff0c;选择当前服务器并在服务器角色中选择ADFS。 完成之后我们需要对ADFS进行详细的配置&#xff0c;在服务器管理…

路由器和交换机的综合实验

路由器和交换机的综合实验<?xml:namespace prefix o ns "urn:schemas-microsoft-com:office:office" />主要目标&#xff1a;1. 跨交换机&#xff08;二层交换机&#xff09;的相同VLAN 之间的通讯2. 不同VLAN之间的通讯1&#xff09; 通过路由器实现不同VL…

如何写出符合Python审美的代码风格?

作者 | Rocky0429来源 | Python空间本文为 AI科技大本营投稿文章&#xff08;欢迎给我们投稿&#xff0c;投稿请联系微信1092722531&#xff09;写在之前每个人都有自己的代码风格&#xff0c;随着写的行数增加&#xff0c;自己对于代码的审美也会变的不一样&#xff0c;这就像…

程序员都该懂点 HTTP

作者&#xff1a;developerHaozGithub 地址&#xff1a;developerHaoz说明&#xff1a;本文主要是对 HTTP 基础知识进行总结和归纳&#xff0c;毕竟做 IT 的&#xff0c;网络这一块还是很重要的 本文的主要内容HTTP 是什么URL 详解HTTP 之请求篇HTTP 之响应篇一、HTTP是什么1、…

谁的青春不迷茫,其实我们都一样

如果你为人生画一条浅浅吃苦底线&#xff0c;就别妄想跨越深邃的幸福极限。在熠熠生辉前&#xff0c;总要捱过一段孤独不安的日子。唯有担得起厚重的经历&#xff0c;才能禁得起岁月推敲。记住&#xff1a;一定要努力&#xff0c;但别着急。加油&#xff01; 很庆幸你能以这样好…