主頁 > 後端開發 > 初探paramiko

初探paramiko

2020-10-02 04:42:52 後端開發

paramiko模塊簡介

paramiko是基于SSHv2協議開發的,可用于連接遠程SSH服務器,通過SSH連接執行遠程命令或者檔案傳輸,paramiko支持Python(2.7,3.4+版本),paramiko利用Python C擴展來現簡單的加密,它本身是一個圍繞SSH網路概念的純Python介面,

paramiko分為以下幾個部分

SSH協議核心類

  • Channel
  • Client
  • Message
  • Packetizer
  • Transport

秘鑰認證類
SSH agents
Host keys / known_hosts files
Key handling
Parent key class

  • DSA (DSS)
  • RSA
  • ECDSA
  • Ed25519

GSS-API authentication
GSS-API key exchange

其它功能類

  • Configuration
  • Keywords currently supported
  • Expansion tokens
  • config module API documentation
  • ProxyCommand support
  • Server implementation
  • SFTP

雜類

  • Buffered pipes
  • Buffered files
  • Cross-platform pipe implementations
  • Exceptions

下面對各類進行簡單介紹

 


 

SSH協議核心類

channel類

class paramiko.channel.Channel(chanid)

channel類的描述:

channel是一個SSH傳輸的安全隧道,一個通道類似于一個socket,由于SSH2有一種視窗式的流控制,如果停止從channel中讀取資料,并且其緩沖區已滿,服務器將無法向channel發送更多的資料,直到從channel中讀取其中一些資料,(注意:這不會影響同一傳輸上的其他channel,單個傳輸上的所有channel都是獨立的流控制,)同樣,如果服務器不讀取channel發送的資料,則除非設定超時,否則發送呼叫會一直處于阻塞,

channel類中的常用方法:

__init__(chanid):建構式,channel是由Transport創建的,所以我們不用管,

close():

功能:關閉channel,斷開SSH連接,

引數:無,

回傳值:無,

exec_command(self, command):

功能:執行遠程命令,注意命令執行完成后channel將關閉,不能被復用,

引數:

command(str):要執行的命令,

回傳值:元組(stdin, stdout, stderr),

exit_status_ready():

功能:當服務端主動斷開連接時,接收服務端的退出狀態碼,如果因為程式假死,或者服務器宕機等特殊原因造成exit_status_ready()無法接收到退出狀態碼,該方法將無法通過獲取狀態碼的形式來判斷服務器的狀態,

引數:無

回傳值:如果接收到服務器退出狀態碼回傳True,否則回傳False,

fileno():

功能:在使用Python的select模塊時會用到fileon()回傳的檔案描述符FD,如果有很多channel都使用此方法將導致channel讀取的效率變慢,

引數:無

回傳值:回傳一個作業系統級檔案描述符(int)FD,該描述符不用于讀取或寫入,

get_id():

功能:回傳channel的ID,通常是一個很小的數字,

引數:無

回傳值:channel的ID,

get_name():

功能:獲取channel的名字,可以使用set_name設定channel的名字,

引數:無

回傳值:channel的名字,

get_pty(term="vt100",width=80,height=24,width_pixels=0,height_pixels=0):

功能:向服務器請求獲取一個偽終端,通常在創建channel后,立即呼叫get_pty()請求一個偽終端,在使用invoke_shell想要創建一個互動式shell環境時需要提前呼叫get_pty(),如果呼叫的是exec_command執行命令,不需要使用get_pty(),

引數:

term(str):要模擬的終端型別,如:'vt100',
width(int):終端寬度,以字符為單位,
height(int):終端高度,以字符為單位,
width_pixels(int):終端寬度,以像素為單位,
height_pixels(int):終端高度,以像素為單位,

回傳值:無

resize_pty(self, width=80, height=24, width_pixels=0, height_pixels=0):

功能:執行get_pty()后,可以通過resize_pty()重新設定偽終端視窗大小,

引數:同get_pty(),

回傳值:無

invoke_shell(self):

功能:前面使用get_pty()獲取一個偽終端后,需要使用invoke_shell()激活這個偽終端,激活成功后在偽終端中就可以向操作本機一樣操作遠程主機即所謂的互動式shell,當退出偽終端后,channel將被關閉,無法被復用,

引數:無

回傳值:無

recv(nbytes):

功能:從channel中接收nbytes的資料,并以位元組的形式回傳,

引數:

nbytes(int):接收的最大位元組數,

回傳值:以位元組的形式回傳接收到的資料,

recv_exit_status():

功能:接收服務器行程回傳退出狀態碼,對于檢索執行命令的結果非常有用,如果命令尚未完成,則此方法將等待完成,或者直到通道關閉,如果服務器沒有提供退出狀態,則回傳-1,

引數:無

回傳值:如果接收到狀態碼回傳狀態碼,否則回傳-1,

recv_ready():

功能:如果channel中有可讀資料回傳True,否則回傳False,但回傳False并不意味著通道已關閉,或者沒有可讀取的資料,有可能需要等待更多的資料到達后在進行讀取,

引數:無

回傳值:如果channel中有可讀資料回傳True,否則回傳False,

recv_stderr(nbytes):

功能:從channel中的stderr流接收nbytes位元組的資料,此方法只在不呼叫get_pty的情況下使用exec_command或invoke_shell時channel中stderr流上才擁有資料,

引數:

nbytes(int):接收最大的位元組數,

回傳值: 從channel中的stderr流接收到的資料(位元組),

recv_stderr_ready():

功能:判斷channel中是否有可讀的stderr流,此方法只在不呼叫get_pty的情況下使用exec_command或invoke_shell時channel中stderr流上才擁有資料,

引數:無

回傳值: 如果channel中有stderr流回傳True,否則回傳False,

request_forward_agent( handler):

功能:在channel上請求轉發SSH代理, 僅對來自OpenSSH的ssh-agent有效!

引數:

handler:handler是用于傳入SSH Agen連接的必需可呼叫處理程式 ,

回傳值:沒太懂,貌似只要執行了就回傳True,

get_transport():

功能:獲取與channel關聯的Transport物件,

引數:無

回傳值:Transport物件

getpeername():

功能:獲取遠程服務器的地址,

引數:無

回傳值:遠程服務器的地址

gettimeout():

功能:呼叫“ setblocking”或“ settimeout”設定超時鍵后,可以使用此方法獲取超時時間單位秒,如果沒有設定超時時間回傳None,

引數:無

回傳值:如果設定超時時間回傳超時時間單位秒,否則回傳None,

def request_x11(screen_number=0,

auth_protocol=None,

auth_cookie=None,

single_connection=False,

handler=None):

功能:在channel上請求x11會話, 如果服務器允許,則在Shell會話中運行x11應用程式時,可以從服務器向客戶端發出進一步的x11請求,

引數:

screen_number(int):螢屏號取值范圍0-10,
auth_protocol(str):X11身份驗證使用的協議,如果未指定默認使用“MIT-MAGIC-COOKIE-1”,
auth_cookie(str):x11身份驗證cookie的十六進制字串;如果沒有給定,生成一個安全的隨機128位值,
single_connection(bool):如果為True,則僅轉發一個x11連接,為False可以轉發任意數量的x11連接,
handler=None:handler是X11連接的可選可呼叫處理程式,

回傳值:身份驗證的cookie,

send( s):

功能:發送資料給服務端,s是要發送的資料,但由于發送緩沖大小的原因資料可能無法被一次性發完,需要開發人員檢測資料是否被全部發送,如果資料沒有發送完,需要再次發送后續資料,直到資料全部發送,

引數:
s(str):是要發送的資料,

回傳值:發送的位元組數,

send_exit_status(status):

功能:向客戶端發送退出狀態碼,僅當作為服務端時才有效,

引數:

status(int):退出狀態碼,

回傳值:無

send_ready():

功能:如果channel不需要阻塞可以立即向發送緩沖區中寫入資料回傳True,否則回傳False,注意,如果channel已關閉,任何嘗試向channel發送緩沖區寫入資料都會被立即回傳,因為無法寫入所以被立即回傳,這種情況send_ready也會回傳True,

引數:無

回傳值:如果channel不需要阻塞可以立即向發送緩沖區中寫入資料回傳True,否則回傳False,

send_stderr(s):

功能:向客戶端發送stderr流,僅當作為服務端時才有效,需要開發人員檢測資料是否被全部發送,如果資料沒有發送完,需要再次發送后續資料,直到資料全部發送,

引數:

s(str):要發送的資料,

回傳值:發送的位元組數,

sendall(s):

功能:將資料全部發送出去,與send的區別是,sendall會自動將所有資料全部發送,不需要人為干預,

引數:

s(str):要發送資料,

回傳值:無

sendall_stderr(s):

功能:向客戶端發送stderr流,僅當作為服務端時才有效,與send_stderr區別是sendall_stderr會自動將所有資料全部發送,不需要人為干預,

回傳值:無

set_combine_stderr(combine):

功能:是否將channel中stderr流和stdout流進行合并,默認combine=False,如果為false表示不合并,在呼叫exec_command后只能通過recv_stderr來獲取channel中的stderr流,而不能使用recv,如果為True,表示將stderr流和stdout流進行合并,則無法通過recv_stderr來獲取stderr流,因為stderr已經合并到stdout流中,可以使用recv來獲取,

引數:

combine(bool):True|False,

回傳值:設定的combine的值,

set_environment_variable(name, value):

功能:設定環境變數的值,注意:如果服務端在組態檔中設定AcceptEnv拒絕客戶端設定環境變數,該方法將不會提示設定失敗,

引數:

name(str):環境變數,

value(str):環境變數的值,

回傳值:無

set_name(name):

功能:給channel設定一個名字,

引數:

name(str):channel的名字,

回傳值:無

setblocking(blocking):

功能:設定channel的阻塞模式,如果blocking為0表示非阻塞模式,否則為阻塞模式,在非阻塞模式下如果recv無法立即接收到資料,或者send無法立即發送資料將會引發錯誤例外,在阻塞模式下send或recv會一直等待執行完成,EOF條件被視為recv的“立即資料”,因此,如果channel在讀取方向上關閉,則它將永遠不會阻塞,

引數:

blocking(int):如果是0表示阻塞非阻塞模式,非0是阻塞模式blocking表示的是阻塞時間單位是秒,如果blocking是1表示一直阻塞,直到執行完成,

回傳值:無

settimeout(timeout):

功能:設定超時時間,與setblocking功能類似,不同之處在于timeout可以是None,而setblocking中的blocking引數只能是int型別,而blocking=1就相當于timeout=None,所以兩者功能上基本類似,

引數:

timeout(float):超時時間單位秒,如果timeout為None阻塞模式,一直等到recv接收完成,或send發送完成,

回傳值:無

shutdown(how):

功能:關閉連接的發送端或者接收端,也可以全部關閉,

引數:

how(int):如果how=0,關閉接收端,如果how=1,關閉發送端,如果how=2,關閉發送端和接收端,

回傳值:無

shutdown_read()

功能:關閉連接的接收端,相當于shutdown(0),

引數:無

回傳值:無

shutdown_write():

功能:關閉連接的發送端,相當于shutdown(1),

引數:無

回傳值:無

update_environment(environment):

功能:更新遠程服務器的環境變數,注意:如果服務端在組態檔中設定AcceptEnv拒絕客戶端設定環境變數,該方法將不會提示設定失敗,

引數:

environment(dict):是一個{'環境變數名':'環境變數的值',...},

回傳值:無


 

SSHClient類

class paramiko.client.SSHClient:

描述:

SSHClient是與SSH服務器回話的高級封裝,其內部實作了身份驗證,執行命令等大多數基礎功能,

close():

功能:關閉SSHClient物件及其底層的Transport,使用完SSHClient物件后,最好呼叫close()關閉物件釋放資源,盡量不依靠python的垃圾回識訓制來關閉SSHClient物件,

引數:無

回傳值:無

connect(hostname, port=22, username=None, password=None, pkey=None,

key_filename=None, timeout=None, allow_agent=True, look_for_keys=True,

compress=False, sock=None, gss_auth=False, gss_kex=False, gss_deleg_creds=True,

gss_host=None, banner_timeout=None, auth_timeout=None, gss_trust_dns=True,

passphrase=None, disabled_algorithms=None)

功能:連接SSH服務器,

引數:

hostname(str):SSH服務器主機地址,

port(int):SSH服務器的埠號,

username(str):登錄SSH服務器的用戶名,

password(str):登錄SSH服務器用戶名的密碼,

pkey(PKey):用于身份驗證的私鑰,

key_filename(str):用于嘗試身份驗證的私鑰或證書的檔案路徑,

time(float):建立TCP連接的超時時間單位是秒,

allow_agent(bool):如果為False,將禁止連接SSH agent,如果為True通過SSH agent獲取私鑰,

look_for_keys(bool):如果為False將禁止在~/.ssh中搜索可用的私鑰,

compress(bool):如果為True將啟用壓縮,

sock(socket):socket物件,

gss_auth(bool):如果為True可以使用GSS-API進行認證,

gss_kex(bool):執行GSS-API密鑰交換和用戶身份驗證,

gss_deleg_creds(bool):是否委托GSS-API客戶端憑據,

gss_host(str):kerberos資料庫中的目標名稱,默認是hostname的值,

gss_trus_dns(bool):是否信任DNS安全規范化所連接主機的名稱(默認為True),

banner_timeout(float):SSH連接成功后banner資訊出現的超時時間單位為秒,

auth_timeout(float):身份認證的超時時間,單位為秒,

disabled_algroitms(dict):直接傳遞給Transport的可選dict及其同名的關鍵字引數,

注意:

Changed in version 1.15: Added the banner_timeout, gss_auth, gss_kex, gss_deleg_creds and gss_host arguments.
Changed in version 2.3: Added the gss_trust_dns argument.
Changed in version 2.4: Added the passphrase argument.
Changed in version 2.6: Added the disabled_algorithms argument.

身份認證的優先級順序(由高到底):

  • pkey和key_filename優先級相同,
  • 通過SSH agent獲取私鑰(allow_agent=True),
  • 本地~/.ssh中發現的“id_rsa”、“id_dsa”或“id_ecdsa”密鑰,
  • 通過用戶名密碼的方式進行驗證,

exec_command(
command,
bufsize=-1,
timeout=None,
get_pty=False,
environment=None,
):

功能:執行遠程命令

引數:

command(str):要執行的命令,多條命令用分號隔開,

bufsize(int):0 表示不緩沖,如果為 1 表示進行行緩沖,大于 1 為緩沖區大小,

timeout(float):命令執行的超時時間,單位秒,

get_pty(bool):如果為True相當于Channel.get_pty,向服務器請求一個偽終端,

environment(dict):在執行命令時附加環境變數,

回傳值:回傳一個元組 (stdin, stdout, and stderr)

get_host_keys():

功能:獲取本機秘鑰,

引數:無

回傳值:本地秘鑰HostKey物件,

get_transport():

功能:獲取一個關于當前SSH連接的Transport物件,該物件可用于創建channel,

引數:無

回傳值:Transport物件,

invoke_shell(
term="vt100",
width=80,
height=24,
width_pixels=0,
height_pixels=0,
environment=None,
):

功能:創建一個新的channel,向SSH服務器請求一個偽終端,建立互動式shell環境,

引數:

term(str):終端型別,

width(int):終端寬度(即以字符為計算單位),

height(int):終端高度(即以字符為計算單位),

witth_pixels(int):終端寬度(即以像素為計算單位),

height_pixels(int):終端高度(即以像素為計算單位),

environment(dict):環境變數,

回傳值:回傳一個建立好互動環境的channel物件,

load_host_keys(filename):

功能:從本地檔案中讀取秘鑰后,通過呼叫load_system_host_keys對其秘鑰進行檢查,檢查完成后呼叫save_host_keys()將秘鑰保存回源檔案當中,秘鑰保存在秘鑰保存在self._entries中,當連接一臺未知的主機時,預設策略AutoAddPolicy會將load_host_keys讀取到的秘鑰添加到自己的秘鑰集合中用于驗證未知的服務器,

引數:

filename(str):秘鑰檔案路徑,

回傳值:無

load_system_host_keys(filename=None):

功能:從本地加載秘鑰,如果filename=None,將從本地如~/.ssh下獲取相關秘鑰檔案(不適用于Windows系統),該方法以只讀的方式讀取秘鑰,秘鑰讀取后不會進行回寫,秘鑰保存在self._entries中,

引數:

filename(str):秘鑰檔案路徑,

回傳值:無

open_sftp():

功能:在SSH服務器打開一個SFTP回話,

引數:無

回傳值:SFTPClient物件,

save_host_keys(filename):

功能:將主機秘鑰存回源檔案,僅當使用load_host_keys()方法時,該方法才有效,

引數:

filename(str):秘鑰檔案路徑,

回傳值:無

set_log_channel(name):

功能:設定channel在日志中的名字,默認是paramiko.transport,

引數:

name(str):channel在日志中的名字,可以是任意名字,

回傳值:無

set_missing_host_key_policy(policy):

功能:設定一個秘鑰策略,當連接一臺沒有沒有該主機秘鑰的主機時,使用的秘鑰策略,

引數:

policy(MissingHostKeyPolicy):秘鑰策略,MissingHostKeyPolicy有三種秘鑰策略:RejectPolicy,AutoAddPolicy,WarningPolicy,

class paramiko.client.RejectPolicy:

功能:秘鑰策略,拒絕連接未知秘鑰的主機,已知的主機秘鑰是指由load_system_host_keys 和load_host_keys從檔案中讀取到的秘鑰,該秘鑰保存在在self._entries中,如果self._entries中沒有主機對應的秘鑰條目則視為未知的主機,

class paramiko.client.WarningPolicy:

功能:秘鑰策略,允許連接未知秘鑰的主機,通過用戶提供的秘鑰對主機進行連接,但會發出警告,如下:

class paramiko.client.AutoAddPolicy:

功能:秘鑰策略,允許連接未知秘鑰的主機,并自動將主機和對應的秘鑰添加到本地的HostKeys中,

回傳值:無

 

參考檔案:http://docs.paramiko.org/en/stable/

======================================================================================

 

                                未完待續

 

======================================================================================

 

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

標籤:Python

上一篇:手把手教你爬取天堂網1920*1080大圖片(批量下載)——實戰篇

下一篇:人工智能學習筆記006-檔案讀寫基礎

標籤雲
其他(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)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more