欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django請求響應(yīng)Web Http交互的核心機(jī)制深入理解

 更新時間:2023年09月03日 11:06:01   作者:techlead_kris  
本文深入探討了 Django 中的請求與響應(yīng)處理,從 Django 請求和響應(yīng)的基礎(chǔ)知識、生命周期,到 HttpRequest 和 HttpResponse 對象的詳細(xì)介紹,同時,討論了 Django 的視圖和請求、響應(yīng)處理,以及安全性和異步處理的考慮

1. Django 請求HttpRequest和響應(yīng)HttpResponse的基礎(chǔ)知識

對比了 Django 與 Flask、FastAPI 等框架在請求響應(yīng)處理上的異同。無論您是 Django 新手還是有經(jīng)驗(yàn)的開發(fā)者,這篇文章都能幫助您更好地理解 Django 的請求和響應(yīng)處理。

在Web應(yīng)用程序中,請求和響應(yīng)模式是非常重要的概念。當(dāng)用戶在瀏覽器地址欄輸入一個URL或者點(diǎn)擊某個鏈接時,會向服務(wù)器發(fā)送一個請求。服務(wù)器處理完這個請求后,會返回一個響應(yīng)給瀏覽器。這就是典型的HTTP請求-響應(yīng)模式。

1.1 Django 的請求對象HttpRequest

在 Django 中,當(dāng)一個 HTTP 請求到達(dá) Django 應(yīng)用時,它首先會被某個URLconf文件轉(zhuǎn)化為一個 HttpRequest 對象。這個對象包含了這次HTTP請求的所有相關(guān)的信息。

def view(request):
    # request 是一個 HttpRequest 對象
    print(request.method)  # 輸出請求方法,比如 "GET" 或 "POST"

1.2 Django 的響應(yīng)對象HttpResponse

Django的視圖必須返回一個 HttpResponse 對象。這個對象表示服務(wù)器給客戶端(通常是瀏覽器)的響應(yīng)。這個 HttpResponse 對象會被轉(zhuǎn)化為一個 HTTP 響應(yīng),然后被發(fā)送到客戶端。

from django.http import HttpResponse

def view(request):
    # 創(chuàng)建一個 HttpResponse 對象
    response = HttpResponse("Hello, World!")
    return response  # 這個響應(yīng)將會被發(fā)送給客戶端

1.3 HTTP 方法Get/Post

HTTP 方法是客戶端可以對服務(wù)器發(fā)出的一種 "指令"。最常見的方法包括 GET 和 POST。

  • GET: 通常用于獲?。ɑ虿樵儯┵Y源信息。
  • POST: 通常用于更新資源信息。

在 Django 中,你可以通過 HttpRequest 對象的 method 屬性來訪問這個請求的方法:

def view(request):
    print(request.method)  # 輸出請求方法,比如 "GET" 或 "POST"

2. Django 請求的生命周期

一旦Django應(yīng)用收到了一個HTTP請求,它會經(jīng)歷一系列的階段,這些階段共同構(gòu)成了請求的生命周期。以下是這個過程的詳述:

2.1 請求到達(dá)

當(dāng)一個請求到達(dá)Django應(yīng)用時,它首先會被WSGI服務(wù)器接收。Django項(xiàng)目被WSGI服務(wù)器(如Gunicorn或uWSGI)作為一個Python應(yīng)用程序運(yùn)行。

# 這是一個簡單的WSGI應(yīng)用的示例,當(dāng)然,實(shí)際的Django WSGI應(yīng)用更加復(fù)雜
def application(environ, start_response):
    start_response('200 OK', [('Content-Type', 'text/plain')])
    return [b"Hello World!"]

2.2 URL 解析

接下來,請求會被送到URL解析器,URL解析器會根據(jù)URLConf模塊中定義的URL模式列表對URL進(jìn)行匹配。URL模式是使用Python的正則表達(dá)式來定義的。

# urls.py
from django.urls import path

from . import views

urlpatterns = [
    path('articles/2003/', views.special_case_2003),
    path('articles/<int:year>/', views.year_archive),
]

2.3 視圖處理

一旦URL解析器找到了匹配的模式,它會調(diào)用與該模式關(guān)聯(lián)的視圖函數(shù),并將HttpRequest對象和從URL中提取的任何參數(shù)傳遞給該視圖。

# views.py
from django.http import HttpResponse

def special_case_2003(request):
    return HttpResponse("Special case for 2003")

def year_archive(request, year):
    return HttpResponse(f"Articles for {year}")

2.4 響應(yīng)返回

視圖函數(shù)處理完請求后,會創(chuàng)建一個HttpResponse對象并返回。這個響應(yīng)對象會經(jīng)過中間件的一系列處理,最終會被轉(zhuǎn)換為一個HTTP響應(yīng),然后發(fā)送給客戶端。

# 視圖函數(shù)返回一個響應(yīng)
def view(request):
    response = HttpResponse("Hello, World!")
    return response  # 這個響應(yīng)將會被發(fā)送給客戶端

3. Django HttpRequest詳述

在 Django 中,所有的 HTTP 請求都被封裝在 HttpRequest 對象中。下面我們將詳細(xì)介紹 HttpRequest 對象的常見屬性和方法。

3.1 HttpRequest 屬性

HttpRequest 對象有很多屬性,可以幫助我們獲取 HTTP 請求的詳細(xì)信息。以下是一些最常用的屬性:

  • path: 一個字符串,表示請求的路徑,不包括域名或者站點(diǎn)根 URL 的路徑。
  • method: 一個字符串,表示 HTTP 請求的方法。常見的值有 "GET","POST" 等。
  • GET: 一個類似字典的對象,包含所有的 GET 參數(shù)。
  • POST: 一個類似字典的對象,包含所有的 POST 參數(shù)。
  • COOKIES: 一個字典,包含所有的 cookie。鍵和值都為字符串。
  • FILES: 一個類似字典的對象,包含所有的上傳文件。
  • user: 一個表示當(dāng)前用戶的 User 對象。如果用戶當(dāng)前未登錄,這將是一個 AnonymousUser 實(shí)例。
def view(request):
    # 打印一些 HttpRequest 屬性的值
    print(request.path)  # 輸出請求路徑,比如 "/my-path/"
    print(request.method)  # 輸出請求方法,比如 "GET"
    print(request.GET)  # 輸出 GET 參數(shù),比如 <QueryDict: {'key': ['value']}>
    print(request.user)  # 輸出當(dāng)前用戶,如果用戶未登錄,將輸出 AnonymousUser

3.2 HttpRequest 方法

除了屬性,HttpRequest 對象還有一些有用的方法:

  • is_ajax(): 如果請求是通過 XMLHttpRequest 發(fā)出的,返回 True。
  • is_secure(): 如果請求是通過 HTTPS 發(fā)出的,返回 True。
  • is_authenticated(): 如果當(dāng)前用戶已經(jīng)登錄,返回 True。
def view(request):
    # 打印一些 HttpRequest 方法的返回值
    print(request.is_ajax())  # 如果請求是 AJAX 請求,輸出 True
    print(request.is_secure())  # 如果請求是 HTTPS 請求,輸出 True
    print(request.is_authenticated())  # 如果當(dāng)前用戶已登錄,輸出 True

4. Django 視圖View和請求HttpRequest處理

在 Django 中,視圖是一個 Python 函數(shù),用于接收一個 Web 請求并返回一個 Web 響應(yīng)。這個響應(yīng)可以是 Web 頁面的 HTML 內(nèi)容,重定向,404 錯誤,XML 文檔,圖像,或者任何其他類型的內(nèi)容。簡單來說,Django 視圖的任務(wù)就是接受一個 Web 請求并返回一個 Web 響應(yīng)。

4.1 創(chuàng)建視圖

在 Django 中,創(chuàng)建一個視圖只需要定義一個 Python 函數(shù),這個函數(shù)需要接受一個 HttpRequest 對象作為第一個參數(shù),然后返回一個 HttpResponse 對象。如下所示:

from django.http import HttpResponse

def hello(request):
    return HttpResponse("Hello, World!")

在這個例子中,hello 函數(shù)就是一個視圖,它接收一個 HttpRequest 對象,然后返回一個包含 "Hello, World!" 的 HttpResponse 對象。

4.2 視圖參數(shù)

視圖函數(shù)的第一個參數(shù)總是 HttpRequest 對象,而從 URL 中捕獲的參數(shù)將作為額外的參數(shù)傳遞給視圖函數(shù)。例如:

from django.http import HttpResponse

def hello(request, name):
    return HttpResponse(f"Hello, {name}!")

在這個例子中,hello 視圖接受兩個參數(shù):一個 HttpRequest 對象和一個 name 字符串。你可以在 URLConf 中定義如何從 URL 中提取這個 name 參數(shù)。

4.3 HttpResponse 對象

視圖必須返回一個 HttpResponse 對象。HttpResponse 類在 django.http 模塊中定義,表示一個 HTTP 響應(yīng),或者說是一個服務(wù)器給客戶端的回應(yīng)。

HttpResponse 對象通常包含文本內(nèi)容,可以是 HTML,也可以是 JSON。除了文本內(nèi)容,你還可以通過設(shè)置 HttpResponse 的不同屬性(比如 content_type 和 status)來控制其他 HTTP 響應(yīng)的參數(shù)。

from django.http import HttpResponse

def hello(request):
    response = HttpResponse("Hello, World!", content_type="text/plain", status=200)
    return response

5. Django HttpResponse詳述

HttpResponse 對象是 Django 視圖中返回的結(jié)果對象,它是由 Django 視圖返回并通過 Django 框架傳送給客戶端的。

5.1 HttpResponse 屬性

HttpResponse 對象有一些常用的屬性,我們可以使用它們來定義我們的響應(yīng)。以下是一些常見的屬性:

  • content: 響應(yīng)的主體內(nèi)容,通常為一個字符串或字節(jié)串。
  • status_code: HTTP 狀態(tài)碼,如 200、404 等。
  • content_type: 響應(yīng)的 MIME 類型,默認(rèn)為 'text/html'。
from django.http import HttpResponse

def view(request):
    response = HttpResponse()
    response.content = "Hello, World!"
    response.status_code = 200
    response.content_type = 'text/plain'
    return response

5.2 HttpResponse 方法

除了屬性,HttpResponse 對象還有一些有用的方法:

  • set_cookie(key, value, max_age=None, expires=None): 設(shè)置一個 Cookie。key 是 Cookie 的名字,value 是 Cookie 的值。max_age 是 Cookie 的最大生存時間,單位是秒。expires 是 Cookie 的過期時間,是一個 datetime 對象或 UNIX 時間戳。
  • delete_cookie(key): 刪除一個 Cookie。
from django.http import HttpResponse

def view(request):
    response = HttpResponse("Hello, World!")
    response.set_cookie('my_cookie', 'cookie_value', max_age=60*60*24)  # 設(shè)置一個一天后過期的 Cookie
    return response

5.3 特殊的 HttpResponse 對象

除了普通的 HttpResponse 對象,Django 還提供了一些特殊的 HttpResponse 對象,用于生成特定的響應(yīng)。例如:

  • JsonResponse: 這個響應(yīng)對象接收一個字典或列表,并返回一個 application/json 類型的響應(yīng)。
  • HttpResponseRedirect: 這個響應(yīng)對象用于生成一個重定向響應(yīng)。
  • HttpResponseNotFound: 這個響應(yīng)對象用于生成一個 404 錯誤響應(yīng)。
from django.http import JsonResponse, HttpResponseRedirect, HttpResponseNotFound

def view_json(request):
    return JsonResponse({'key': 'value'})  # 返回一個 JSON 響應(yīng)

def view_redirect(request):
    return HttpResponseRedirect('/another-url/')  # 重定向到另一個 URL

def view_404(request):
    return HttpResponseNotFound('<h1>Page not found</h1>')  # 返回一個 404 錯誤

6. Django 視圖View和HttpResponse響應(yīng)處理

在 Django 中,視圖是 Web 請求的主要處理者,同時也負(fù)責(zé)構(gòu)建和返回響應(yīng)。視圖接收 HttpRequest 對象作為參數(shù),生成 HttpResponse 對象作為返回值。我們已經(jīng)詳細(xì)討論了 HttpRequest 和 HttpResponse,現(xiàn)在我們來看看如何在視圖中處理它們。

6.1 處理請求

處理請求主要是提取 HttpRequest 對象的數(shù)據(jù),然后根據(jù)這些數(shù)據(jù)執(zhí)行相應(yīng)的邏輯。

def view(request):
    # 獲取 GET 請求的參數(shù)
    name = request.GET.get('name', 'Guest')
    # 根據(jù)請求參數(shù)執(zhí)行邏輯
    message = f"Hello, {name}!"
    return HttpResponse(message)

在這個例子中,我們從 GET 請求中獲取 'name' 參數(shù),然后用它來生成一條歡迎消息。

6.2 構(gòu)建響應(yīng)

構(gòu)建響應(yīng)主要是創(chuàng)建 HttpResponse 對象,然后填充其內(nèi)容。

def view(request):
    # 創(chuàng)建 HttpResponse 對象
    response = HttpResponse()
    # 填充響應(yīng)內(nèi)容
    response.content = "Hello, World!"
    response.status_code = 200
    response['Content-Type'] = 'text/plain'
    return response

在這個例子中,我們創(chuàng)建了一個 HttpResponse 對象,然后設(shè)置了其內(nèi)容、狀態(tài)碼和 Content-Type 頭。

6.3 快捷方式

在 Django 視圖中,我們經(jīng)常需要做一些常見的操作,比如渲染一個模板,重定向到另一個 URL,或者返回一個 404 錯誤。為了簡化這些操作,Django 提供了一些快捷方式。

from django.shortcuts import render, redirect, get_object_or_404
from .models import MyModel

def view(request):
    # 渲染一個模板
    context = {'key': 'value'}
    return render(request, 'my_template.html', context)

def redirect_view(request):
    # 重定向到另一個 URL
    return redirect('/another-url/')

def detail_view(request, pk):
    # 獲取一個對象或返回 404 錯誤
    obj = get_object_or_404(MyModel, pk=pk)
    return render(request, 'detail.html', {'obj': obj})

7. Django 請求和響應(yīng)的安全性考慮

在處理 Web 請求和生成響應(yīng)時,安全性是一個非常重要的考慮因素。幸運(yùn)的是,Django 提供了一些內(nèi)置的工具和技術(shù)來幫助我們增加應(yīng)用程序的安全性。

7.1 CSRF 保護(hù)

跨站請求偽造(CSRF)是一種攻擊方式,攻擊者可以偽造用戶的請求。Django 提供了 CSRF 保護(hù)機(jī)制,可以在處理 POST 請求時自動檢查 CSRF 令牌。

from django.views.decorators.csrf import csrf_exempt

@csrf_exempt  # 用這個裝飾器來禁用 CSRF 保護(hù)
def my_view(request):
    # view code here...

在大多數(shù)情況下,你應(yīng)該讓 Django 自動處理 CSRF 保護(hù)。但是在某些情況下,你可能需要禁用它,比如上面的例子。

7.2 安全的數(shù)據(jù)存儲

當(dāng)你在處理請求時接收到敏感信息,如密碼,你應(yīng)該使用 Django 提供的安全方法來存儲這些信息。

from django.contrib.auth.hashers import make_password

def register(request):
    password = request.POST['password']
    hashed_password = make_password(password)  # 使用哈希函數(shù)來安全存儲密碼
    # save hashed_password to database...

7.3 HTTP 響應(yīng)頭的安全設(shè)置

Django 提供了一些設(shè)置,你可以使用它們來增加 HTTP 響應(yīng)頭的安全性,如 SECURE_CONTENT_TYPE_NOSNIFF 和 SECURE_BROWSER_XSS_FILTER。你可以在你的 Django 設(shè)置中配置它們。

# settings.py
SECURE_CONTENT_TYPE_NOSNIFF = True
SECURE_BROWSER_XSS_FILTER = True

7.4 用戶輸入的安全處理

永遠(yuǎn)不要信任用戶輸入的數(shù)據(jù)。你應(yīng)該始終對用戶輸入的數(shù)據(jù)進(jìn)行清洗和驗(yàn)證。

from django.core.exceptions import ValidationError

def view(request):
    comment = request.POST['comment']
    if len(comment) > 100:
        raise ValidationError("Comment is too long!")
    # save comment to database...

8. Django 異步請求和響應(yīng)

Django 3.1 引入了異步視圖和中間件支持,這意味著你可以使用 Python 的 async 和 await 關(guān)鍵字來處理異步任務(wù)。這對于處理 I/O 綁定任務(wù)或其他可以從并發(fā)執(zhí)行中受益的任務(wù)非常有用。

8.1 異步視圖

創(chuàng)建異步視圖的方式與創(chuàng)建同步視圖非常相似,但是你需要將視圖函數(shù)定義為 async def 函數(shù),然后在函數(shù)體中使用 await 關(guān)鍵字。

from django.http import JsonResponse

async def async_view(request):
    data = await get_data()  # 假設(shè) get_data 是一個異步函數(shù)
    return JsonResponse(data)

在這個例子中,get_data 是一個異步函數(shù),我們使用 await 關(guān)鍵字來調(diào)用它。當(dāng) Django 等待 get_data 完成時,它可以釋放服務(wù)器資源來處理其他請求。

8.2 異步中間件

你也可以創(chuàng)建異步中間件,它可以處理進(jìn)入視圖之前或離開視圖之后的請求和響應(yīng)。

class SimpleMiddleware:
    async def __call__(self, request, get_response):
        response = await get_response(request)
        return response

在這個例子中,SimpleMiddleware 是一個異步中間件,它在處理請求之前和之后沒有做任何事情,只是簡單地將請求傳遞給下一個中間件或視圖。

8.3 數(shù)據(jù)庫操作

在 Django 的異步視圖或中間件中,你不應(yīng)該執(zhí)行同步的數(shù)據(jù)庫操作,因?yàn)檫@可能會阻塞事件循環(huán)。你應(yīng)該使用 Django 提供的 asgiref.sync.sync_to_async 函數(shù)將同步的數(shù)據(jù)庫操作包裝到一個線程中。

from asgiref.sync import sync_to_async
from django.contrib.auth.models import User
async def async_view(request):
    get_user = sync_to_async(User.objects.get)
    user = await get_user(id=1)
    return JsonResponse({'username': user.username})

在這個例子中,我們使用 sync_to_async 函數(shù)將 User.objects.get 包裝到一個線程中,然后在異步視圖中使用 await 關(guān)鍵字來調(diào)用它。

當(dāng)然,接下來我們就來比較一下 Django 與其他主流 Python 框架(如 Flask 和 FastAPI)在請求和響應(yīng)處理上的異同。

總結(jié): Django 與其他主流 Python 框架在請求響應(yīng)部分的比較

Django vs Flask

Flask 是另一個流行的 Python web 框架,相比 Django,F(xiàn)lask 是一個更為輕量級的框架,具有更高的定制性。

  • 請求對象: Flask 的 request 對象和 Django 的 HttpRequest 對象在許多方面是相似的,但 Flask 的 request 對象在語法上更為簡潔。在 Flask 中,你可以直接通過 request.form['key'] 來訪問 POST 參數(shù),而在 Django 中,你需要使用 request.POST.get('key')
  • 響應(yīng)對象: Flask 允許你直接從視圖返回字符串,然后自動將其轉(zhuǎn)化為 Response 對象,而 Django 則需要你顯式地創(chuàng)建一個 HttpResponse 對象。
  • URL 參數(shù): Flask 提供了一種簡潔的方式來在 URL 中定義參數(shù),如 @app.route('/user/<username>'),而在 Django 中,你需要在 urls.py 中使用正則表達(dá)式來定義 URL 參數(shù)。
# Flask
@app.route('/user/&lt;username&gt;')
def show_user_profile(username):
    # show the user profile for that user
    return 'User %s' % username

# Django
from django.urls import path

def show_user_profile(request, username):
    # show the user profile for that user
    return HttpResponse('User %s' % username)

urlpatterns = [
    path('user/&lt;str:username&gt;/', show_user_profile),
]

Django vs FastAPI

FastAPI 是一個新興的 Python web 框架,它的特色是快速、簡單和高性能,而且內(nèi)建對異步編程的支持。

  • 類型檢查: FastAPI 支持 Python 的類型檢查,你可以在參數(shù)中直接定義類型,F(xiàn)astAPI 會自動進(jìn)行數(shù)據(jù)驗(yàn)證。而在 Django 中,你需要自己驗(yàn)證數(shù)據(jù)并處理錯誤。
  • 異步編程: 雖然 Django 3.1 開始支持異步視圖和中間件,但是 FastAPI 在異步編程方面的支持更為完善。你可以在 FastAPI 中使用 async 和 await 關(guān)鍵字來定義異步的路徑操作函數(shù),而在 Django 中,你可能需要使用 asgiref.sync.sync_to_async 來包裝數(shù)據(jù)庫操作。
  • 自動文檔: FastAPI 可以根據(jù)你的代碼自動生成 API 文檔,這可以幫助你更好地測試和調(diào)試你的 API。而在 Django 中,你需要使用如 DRF 的第三方庫或手動編寫 API 文檔。
# FastAPI
from fastapi import FastAPI

app = FastAPI()

@app.get("/items/{item_id}")
async def read_item(item_id: int):
    return {"item_id": item_id}

總的來說,Django、Flask 和 FastAPI 都是優(yōu)秀的 Python web 框架,它們各有各的優(yōu)點(diǎn)。選擇哪一個取決于你的項(xiàng)目需求,以及你更傾向于使用哪種編程范式。

以上就是Django請求響應(yīng)Web Http交互的核心機(jī)制深入理解的詳細(xì)內(nèi)容,更多關(guān)于Django Web Http交互的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQLdb ImportError: libmysqlclient.so.18解決方法

    MySQLdb ImportError: libmysqlclient.so.18解決方法

    這篇文章主要介紹了MySQLdb ImportError: libmysqlclient.so.18解決方法,需要的朋友可以參考下
    2014-08-08
  • python實(shí)現(xiàn)給數(shù)組按片賦值的方法

    python實(shí)現(xiàn)給數(shù)組按片賦值的方法

    這篇文章主要介紹了python實(shí)現(xiàn)給數(shù)組按片賦值的方法,實(shí)例分析了Python在指定位置進(jìn)行賦值的相關(guān)技巧,需要的朋友可以參考下
    2015-07-07
  • python如何重載模塊實(shí)例解析

    python如何重載模塊實(shí)例解析

    這篇文章主要介紹了python如何重載模塊實(shí)例解析,涉及模塊的概念,載入和重載的實(shí)例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Python序列對象與String類型內(nèi)置方法詳解

    Python序列對象與String類型內(nèi)置方法詳解

    這篇文章主要介紹了Python序列對象與String類型內(nèi)置方法,結(jié)合實(shí)例形式分析了Python序列對象與String類型各種常見內(nèi)置方法相關(guān)使用技巧及操作注意事項(xiàng),需要的朋友可以參考下
    2019-10-10
  • 解決python DataFrame 打印結(jié)果不換行問題

    解決python DataFrame 打印結(jié)果不換行問題

    這篇文章主要介紹了解決python DataFrame 打印結(jié)果不換行問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 一文詳解為什么運(yùn)行Python就是找不到文件路徑

    一文詳解為什么運(yùn)行Python就是找不到文件路徑

    這篇文章主要介紹了在編程中遇到文件路徑找不到問題的原因和解決方法,包括路徑錯誤、路徑分隔符問題、工作目錄錯誤、權(quán)限問題以及虛擬環(huán)境的影響,并提供了一些實(shí)用的解決方案,通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-01-01
  • Python編程實(shí)戰(zhàn)之Oracle數(shù)據(jù)庫操作示例

    Python編程實(shí)戰(zhàn)之Oracle數(shù)據(jù)庫操作示例

    這篇文章主要介紹了Python編程實(shí)戰(zhàn)之Oracle數(shù)據(jù)庫操作,結(jié)合具體實(shí)例形式分析了Python的Oracle數(shù)據(jù)庫模塊cx_Oracle包安裝、Oracle連接及操作技巧,需要的朋友可以參考下
    2017-06-06
  • Python編程實(shí)現(xiàn)蟻群算法詳解

    Python編程實(shí)現(xiàn)蟻群算法詳解

    這篇文章主要介紹了Python編程實(shí)現(xiàn)蟻群算法詳解,涉及螞蟻算法的簡介,主要原理及公式,以及Python中的實(shí)現(xiàn)代碼,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • python利用腳本輕松實(shí)現(xiàn)ssh免密登陸配置

    python利用腳本輕松實(shí)現(xiàn)ssh免密登陸配置

    這篇文章主要為大家詳細(xì)介紹了python如何利用腳本輕松實(shí)現(xiàn)ssh免密登陸配置,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • python OpenCV 實(shí)現(xiàn)高斯濾波詳解

    python OpenCV 實(shí)現(xiàn)高斯濾波詳解

    這篇文章主要介紹了Python+OpenCV 實(shí)現(xiàn)高斯濾波的過程,關(guān)于高斯濾波的解釋,它是一種線性平滑濾波,適用于消除高斯噪聲,具體實(shí)現(xiàn)過程跟隨小編一起看看吧
    2021-10-10

最新評論