• 从零开始搭建Django博客②--Django的服务器内容搭建

从零开始搭建Django博客②--Django的服务器内容搭建

2025-04-24 15:52:17 2 阅读

本文主要在Ubuntu环境上搭建,为便于研究理解,采用SSH连接在虚拟机里的ubuntu-24.04.2-desktop系统搭建,当涉及一些文件操作部分便于通过桌面化进行理解,通过Nginx代理绑定域名,对外发布。

此为从零开始搭建Django博客系列的第二篇,计划用一周时间完成一个博客搭建并全程记录,便于学习和跟着操作。

从零开始搭建Django博客①–正式开始前的准备工作
从零开始搭建Django博客②–Django的服务器内容搭建

框架理解

我们已经建立了一个基本的名为myblog的Django项目,他的框架如下:

# 项目文件夹结构
├── manage.py  # Django 项目的管理文件
└── myblog  # 项目实际存放目录
    ├── asgi.py  # 运行在 ASGI 兼容的 Web 服务器上的入口
    ├── __init__.py  # 证明该目录此为Python 包。
    ├── settings.py  # Django 项目的配置文件
    ├── urls.py  # Django 项目的 URL 声明,就像你网站的“目录”。
    └── wsgi.py  # 运行在 WSGI 兼容的Web服务器上的入口

网站构建

在Web应用中,通常有一些业务功能模块是在不同的项目中都可以复用的,故在开发中通常将工程项目拆分为不同的子功能模块,各功能模块间可以保持相对的独立,在其他工程项目中需要用到某个特定功能模块时,可以将该模块代码整体复制过去,达到复用。因此我们每个WEB应用都是有很多不同的子应用组成,在Django中,通过APP来创建子应用。
为了实现一个博客,我们需要以下三种功能:
![[Pasted image 20250422111023.png]]

创建APP

在根目录下通过以下代码创建三个app子应用

# 创建文章功能
python manage.py startapp article
# 创建用户功能
python manage.py startapp user
# 创建评论功能
python manage.py startapp comment

此时项目文件夹结构如下,可以发现其中除了我们建立的三个文件夹,又生成了一个db.sqlit3,这是因为在我们未设置数据库信息时,Djangosettings.py 里默认连接的是项目目录里的该数据库。

![[Pasted image 20250422111427.png]]

连接数据库

为了下一步的数据可视化,我们首先配置数据库信息,打开myblog文件夹目录下的settings.py配置数据库信息:
![[Pasted image 20250422114305.png]]
安装pymysql包(用于连接数据库)和cryptography包(用于处理密码)
settings.py同目录下的__init__.py中导入mysql包相关功能

import pymysql 
pymysql.install_as_MySQLdb()

![[Pasted image 20250422114611.png]]
重新启动Djangond服务器,无报错说明配置无误。

注册APP

同样在 myblog文件夹目录下的settings.py 中,找到INSTALLED_APPS配置项,将新创建的3个app添加到项目的app列表,如下

创建模型

在此之前,我们先理解DjangoMVT模式

  • M全拼为Model,负责和数据库交互,进行数据处理。
  • V全拼为View,接收请求,进行业务处理,返回应答。
  • T全拼为Template,负责封装构造要返回的html。

文章模型

数据需求分析

首先分析文章功能需要哪些数据

数据名标题作者创建时间更新时间正文浏览量
idtitleauthorcreatedupdatedbodyviews
类型字符串时间时间大量文本数字
备注外键约束
构建代码
# 文件:article/modle.py
from django.db import models
# 导入django内建的User模型(后面会提)
from django.contrib.auth.models import User
# timezone 用于处理时间相关事务。
from django.utils import timezone
# 用于反向解析,动态生成链接
from django.urls import reverse

# 博客文章数据模型
class ArticlePost(models.Model):
    # 文章标题。models.CharField 为字符串字段,用于保存较短的字符串,比如标题
    title = models.CharField(max_length=100)
    
    # 文章作者。外键约束,参数 on_delete 用于指定数据删除的方式,链接到(User),只要作者(User)被删除,所有该作者的文章数据都会被删除。
    author = models.ForeignKey(User, on_delete=models.CASCADE)

    # 文章创建时间。参数 default=timezone.now 指定其在创建数据时将默认写入当前的时间
    created = models.DateTimeField(default=timezone.now)

    # 文章更新时间。参数 auto_now=True 指定每次数据更新时自动写入当前时间
    updated = models.DateTimeField(auto_now=True)

    # 文章正文。保存大量文本使用 TextField
    body = models.TextField()

    # 文章浏览量
    total_views = models.PositiveIntegerField(default=0)

    # 内部类 class Meta 用于给 model 定义元数据(Django内部类)
    class Meta:
        # ordering 指定模型返回的数据的排列顺序
        # '-created' 表明数据应该以倒序排列
        ordering = ('-created',)

    # 魔术方法 __str__ 定义当调用对象的 str() 方法时的返回值内容。
    def __str__(self):
        # return self.title 将文章标题返回
        return self.title

        # 获取文章地址,按照数据库id解析为url:/article/id
    def get_absolute_url(self):
        return reverse('article:article_detail', args=[self.id])

评论模型

数据需求分析

首先分析文章功能需要哪些数据

数据名评论文章评论作者评论时间正文
idtitleauthorcreatedbody
类型字符串时间大量文本
备注外键约束
构建代码
from django.db import models
from django.contrib.auth.models import User
from article.models import ArticlePost

# 博文的评论
class Comment(models.Model):
# related_name表示可以反向查询文章和用户的评论
    article = models.ForeignKey(ArticlePost,on_delete=models.CASCADE,related_name='comments')
    user = models.ForeignKey(User,on_delete=models.CASCADE,related_name='comments')
    body = models.TextField()
    created = models.DateTimeField(auto_now_add=True)
	# 按照创建时间排序
    class Meta:
        ordering = ('created',)

    def __str__(self):
        return self.body[:20]

数据迁移

编写好了Model后,接下来就需要进行数据迁移。迁移是Django对模型所做的更改传递到数据库中的方式。

注意,每当对数据库进行了更改(添加、修改、删除等)操作,都需要进行数据迁移。

Django的迁移代码是由模型文件自动生成的,它本质上只是个历史记录,Django可以用它来进行数据库的滚动更新,通过这种方式使其能够和当前的模型匹配。

在命令行中输入命令让 Django知道我们自定义模型有一些变更,并根据我们自定义app的模型生成创建数据表的脚本:

python manage.py makemigrations

python manage.py migrate

数据查看

可以通过查看数据库检查数据迁移效果

mysql -u 数据库用户名 -p

输入密码后进入数据库

# 切换到数据库
USE 数据库名;
# 显示数据表
SHOW TABLES;

可以看到数据库中已经有了Django自带的用户数据表和我们创建的文章、评论数据表

创建视图

再看下MVT图:

我们已经构建起Model与数据库之间的联系,下面需要构建模型(Model)与视图(View)之间的关系。
Django 中视图的概念是「一类具有相同功能和模板的网页的集合」。
每一个视图表现为一个简单的Python函数,它需要要做的只有两件事:返回一个包含被请求页面内容的 HttpResponse对象,或者抛出一个异常,比如 Http404
视图函数中的request与网页发来的请求有关,里面包含get或post的内容、用户浏览器、系统等信息。简单来说,视图就是实现将用户的想法通过WEB传递到模型。
根据系统设计过程中需要的功能,我们分别在不同的app 中创建对应的View视图。

文章视图

对于文章,我们需要有以下功能:

  • 文章创建(article_create)
    • 实现文章的创建和提交功能。
  • 文章内容显示(article_detail)
    • 展示文章的标题和内容详情,同时在此视图中取出评论,并展示所有评论列表。
  • 文章删除(article_delete)
    • 实现文章删除功能。
  • 文章修改(article_update)
    • 实现文章的修改功能。
  • 文章排序(article_list)
    • 实现默认按发布日期排序。
    • 实现可按浏览量(热度)排序。
    • 利用Django 的paginator组件实现分页功能。
# 导入Django内部的登录装饰器,可以确保只有登录才能访问相应视图。
from django.contrib.auth.decorators import login_required
# 导入http功能
from django.http import HttpResponse
# 导入render功能和redirect功能
from django.shortcuts import render,redirect
# 导入数据模型ArticlePost
from comment.models import Comment
# 从本目录导入模型
from . import models
# 从本目录的模型中导入文章功能
from .models import ArticlePost
# 引入内置User模型
from django.contrib.auth.models import User
# 引入内置的分页模块
from django.core.paginator import Paginator

# 定义文章创建函数
def article_create(request):
	# 如果用户提交数据,则把相应数据填入变量中
    if request.method == 'POST':
        new_article_title = request.POST.get('title')
        new_article_body = request.POST.get('body')
        # 默认第一个用户作者
        new_article_author = User.objects.get(id=1)
        # 生成一个文章对象,即创建模型。
        models.ArticlePost.objects.create(title=new_article_title, body=new_article_body,author=new_article_author)
        return redirect("article:article_list")
    # 如果用户请求获取数据,则给用户提供一个写文章的界面
    else:
        return render(request, 'article/create.html')
    # 一般都是先请求获取数据--生成写文章界面--写完后再提交数据

# 文章详情
def article_detail(request, id):
    # 取出相应的文章
    article = ArticlePost.objects.get(id=id)
    # 浏览量 +1
    article.total_views += 1
    # 把新的浏览量字段保存数据库
    article.save(update_fields=['total_views'])

    # 取出文章评论
    comments = Comment.objects.filter(article=id)

    # 需要传递给模板的对象
    # context = { 'article': article }
    context = { 'article': article, 'comments': comments }
    # 载入模板,并返回context对象
    return render(request, 'article/detail.html', context)

# 删文章
def article_delete(request, id):
    # 根据 id 获取需要删除的文章
    article = ArticlePost.objects.get(id=id)
    # 调用.delete()方法删除文章
    article.delete()
    # 完成删除后返回文章列表
    return redirect("article:article_list")

# 更新文章
# 提醒用户登录
@login_required(login_url='/userprofile/login/')
def article_update(request, id):
    # # 获取需要修改的具体文章对象
    article = ArticlePost.objects.get(id=id)
    # 过滤非作者的用户
    if request.user != article.author:
        return HttpResponse("抱歉,你无权修改这篇文章。")

    # 判断用户是否为 POST 提交表单数据
    if request.method == "POST":
        new_article_title = request.POST.get('title')
        new_article_body = request.POST.get('body')
        article.title = new_article_title
        article.body = new_article_body
        article.save()
        # 完成后返回到修改后的文章中。需传入文章的 id 值
        return redirect("article:article_detail", id=id)
    else:
        # 赋值上下文,将 article 文章对象也传递进去,以便提取旧的内容
        context = {'article': article}
        return render(request, 'article/update.html', context)

def article_list(request):
    # 根据GET请求中查询条件
    # 如果选择按浏览量排序返回数组
    if request.GET.get('order') == 'total_views':
        article_list = ArticlePost.objects.all().order_by('-total_views')
        order = 'total_views'
    # 否则按照默认排序返回数组
    else:
        article_list = ArticlePost.objects.all()
        order = 'normal'
	# 分页,每页4项
    paginator = Paginator(article_list, 4)
    # 如果选择了页面
    page = request.GET.get('page')
    # 查看该页的文章
    articles = paginator.get_page(page)

    # 返回这些文章模型,并按排序返回
    context = { 'articles': articles, 'order': order }

    return render(request, 'article/list.html', context)

评论视图

在文件comment/views.py文件中创建如下视图函数,评论比较简单,暂时只创建一个添加评论的就可以了:

# 导入相关模块
from django.shortcuts import render, get_object_or_404, redirect
from django.contrib.auth.decorators import login_required
from django.http import HttpResponse
from article.models import ArticlePost
from . import models


# 文章评论
@login_required(login_url='/user/login/')
def post_comment(request, article_id):
    article = get_object_or_404(ArticlePost, id=article_id)
    if request.method == 'POST':
        new_comment_body = request.POST.get('body')
        new_article_user = request.user
        models.Comment.objects.create(article=article, body=new_comment_body,user=new_article_user)
        return redirect(article)
    else:
        return HttpResponse("发表评论仅接受POST请求。")

用户视图

之所以没创建用户模型是因为Django内置了用户模型,我们在开发一些用户权限控制不复杂的网站或者系统时,可以直接采用Django自带的用户认证模块功能,通过视图调用即可。

用户注册登录

用户注册、登录一般都会用到表单,Django中也内置了一个表单组件,首先我们利用该组件构建表单,在user的app中新建forms.py

# 引入表单类
from django import forms
# 引入 User 模型
from django.contrib.auth.models import User

# 登录表单,继承了 forms.Form 类
class UserLoginForm(forms.Form):
    username = forms.CharField()
    password = forms.CharField()

# 注册用户表单
class UserRegisterForm(forms.ModelForm):
    # 复写 User 的密码
    password = forms.CharField()
    password2 = forms.CharField()

    class Meta:
        model = User
        fields = ('username', 'email')

    # 对两次输入的密码是否一致进行检查
    def clean_password2(self):
        data = self.cleaned_data
        if data.get('password') == data.get('password2'):
            return data.get('password')
        else:
            raise forms.ValidationError("密码输入不一致,请重试。")

以上是一个简单的登录、注册表单实现

视图建设

用户视图需要三个功能,登录(验证账号密码)、退出、注册(新建一条用户数据),代码如下:

from django.shortcuts import render, redirect
from django.contrib.auth import authenticate, login,logout
from django.http import HttpResponse
from .forms import UserLoginForm,UserRegisterForm

# Create your views here.
def user_login(request):
    if request.method == 'POST':
        user_login_form = UserLoginForm(data=request.POST)
        if user_login_form.is_valid():
            # .cleaned_data 清洗出合法数据
            data = user_login_form.cleaned_data
            # 检验账号、密码是否正确匹配数据库中的某个用户
            # 如果均匹配则返回这个 user 对象
            user = authenticate(username=data['username'], password=data['password'])
            if user:
                # 将用户数据保存在 session 中,即实现了登录动作
                login(request, user)
                return redirect("article:article_list")
            else:
                return HttpResponse("账号或密码输入有误。请重新输入~")
        else:
            return HttpResponse("账号或密码输入不合法")
    elif request.method == 'GET':
        user_login_form = UserLoginForm()
        context = { 'form': user_login_form }
        return render(request, 'userprofile/login.html', context)
    else:
        return HttpResponse("请使用GET或POST请求数据")

def user_logout(request):
    logout(request)
    return redirect("article:article_list")

# 用户注册
def user_register(request):
    if request.method == 'POST':
        user_register_form = UserRegisterForm(data=request.POST)
        if user_register_form.is_valid():
            new_user = user_register_form.save(commit=False)
            # 设置密码
            new_user.set_password(user_register_form.cleaned_data['password'])
            new_user.save()
            # 保存好数据后立即登录并返回博客列表页面
            login(request, new_user)
            return redirect("article:article_list")
        else:
            return HttpResponse("注册表单输入有误。请重新输入~")
    elif request.method == 'GET':
        user_register_form = UserRegisterForm()
        context = { 'form': user_register_form }
        return render(request, 'userprofile/register.html', context)
    else:
        return HttpResponse("请使用GET或POST请求数据")

配置路由

定义完视图后,我们需要通过路由访问这些视图:
查找视图的过程 :

  • 1.请求者在浏览器地址栏中输入URL, 请求到网站.
  • 2.网站获取URL信息.
  • 3.然后与编写好的URLconf逐条匹配.
  • 4.如果匹配成功则调用对应的视图.
  • 5.如果所有的URLconf都没有匹配成功.则返回404错误.

我们有3个app,Django可以对URL进行分级管理,我们在每个app文件夹内的urls.py分别定义各自app相关的URL,然后在根目录DjangoBlog的urls.py中通过include指令来包含各个app中的URL。

  • 需要两步完成URLconf配置
    • 1.在项目中定义URLconf(到应用)
    • 2.在应用中定义URLconf(应用内)

项目中定义路由(根目录的urls.py)

# 引入用户管理后台
from django.contrib import admin
# 记得引入include
from django.urls import path, include
# 需要使用文章视图显示文章列表作为首页
from article import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', views.article_list, name='home'),
    path('article/', include('article.urls', namespace='article')),
    path('user/', include('user.urls', namespace='user')),
    path('comment/', include('comment.urls', namespace='comment')),
]

应用中定义路由

文章APP(urls.py)

# 引入path
from django.urls import path
# 引入views.py
from . import views

# 正在部署的应用的名称
app_name = 'article'

urlpatterns = [
    path('', views.article_list),
    # path函数将url映射到视图
    path('article-list/', views.article_list, name='article_list'),
    # 文章详情
    path('article-detail//', views.article_detail, name='article_detail'),
    # 写文章
    path('article-create/', views.article_create, name='article_create'),
    # 删除文章
    path('article-delete//', views.article_delete, name='article_delete'),
    # 更新文章
    path('article-update//', views.article_update, name='article_update'),
]

评论APP(urls.py)

# 引入path
from django.urls import path
# 引入views.py
from . import views

# 正在部署的应用的名称
app_name = 'comment'

urlpatterns = [
    # # path函数将url映射到视图
    # 发表评论
    path('post-comment//', views.post_comment, name='post_comment'),
]

用户APP(urls.py)

from django.urls import path
from . import views

app_name = 'user'

urlpatterns = [
    # 用户登录
    path('login/', views.user_login, name='login'),
    # 用户退出
    path('logout/', views.user_logout, name='logout'),
    # 用户注册
    path('register/', views.user_register, name='register'),

]

至此,所有后端工作准备完毕,下面我们建一个前端模板用于显示相关信息:

创建模板

在根目录新建一个templates文件夹,用于存放模板文件。
配置主要目录下的setting.py中的TEMPLATES,绑定当前创建的templates文件夹地址。

前期我们已经在视图中设置了视图传入数据的目标地址,以文章视图为例
我们有如下路由和创建文章功能

当得到GET请求页面127.0.0.1:8000/article/article-create/时,会调取article_create函数返回 article/create.html 页面.
我们直接用html语言简单建立该页面测试一下:

DOCTYPE html>
<html>
<head>
<title>只是测试title>
head>
<body>
<div class="container">
    <div class="row">
        <div class="col-12">
            <br>
            
            <form method="post" action=".">
                
                {% csrf_token %}
                
                <div class="form-group">
                    
                    <label for="title">文章标题label>
                    
                    <input type="text" class="form-control" id="title" name="title">
                div>
                
                <div class="form-group">
                    <label for="body">文章正文label>
                    
                    <textarea type="text" class="form-control" id="body" name="body" rows="12">textarea>
                div>
                
                <button type="submit" class="btn btn-primary">完成button>
            form>
        div>
    div>
div>
body>
html>

访问127.0.0.1:8000/article/article-create/,得到如下页面:

到此,我们已经完成了所有应用模型、视图的搭建,并初步构建了一个文件创建的页面进行验证,下一步我们将针对每一个视图建设模板,完成视图与模板之间的连接。

本文地址:https://www.vps345.com/204.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 javascript 前端 chrome edge deepseek Ollama 模型联网 API CherryStudio python MCP 阿里云 网络 网络安全 网络协议 llama 算法 opencv 自然语言处理 神经网络 语言模型 ssh ubuntu 进程 操作系统 进程控制 Ubuntu harmonyos 华为 开发语言 typescript 计算机网络 数据库 centos oracle 关系型 安全 分布式 github 创意 社区 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn react.js 前端面试题 node.js 持续部署 macos adb ssl java ollama ai 人工智能 llm Dell R750XS 科技 个人开发 udp unity rust http fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse php android pycharm ide pytorch 笔记 C 环境变量 进程地址空间 前端框架 深度学习 YOLO 目标检测 计算机视觉 nginx 监控 自动化运维 智能路由器 外网访问 内网穿透 端口映射 鸿蒙 web安全 Kali Linux 黑客 渗透测试 信息收集 django flask web3.py numpy tcp/ip flutter Hyper-V WinRM TrustedHosts RTSP xop RTP RTSPServer 推流 视频 golang 面试 性能优化 jdk intellij-idea 架构 Deepseek vscode mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 android studio 交互 后端 websocket windows 搜索引擎 ollama下载加速 大模型 经验分享 学习方法 学习 运维开发 云原生 c# rabbitmq es jvm AI编程 dell服务器 go 代理模式 Windsurf IIS .net core Hosting Bundle .NET Framework vs2022 自动化 蓝耘科技 元生代平台工作流 ComfyUI minicom 串口调试工具 测试工具 媒体 微信公众平台 fpga开发 docker 容器 计算机外设 电脑 mac 软件需求 ecm bpm redis mybatis ddos c语言 qt stm32项目 单片机 stm32 机器学习 chatgpt llama3 Chatglm 开源大模型 系统开发 binder 车载系统 framework 源码环境 vim kylin c++ 深度优先 图论 并集查找 换根法 树上倍增 ffmpeg 音视频 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 mysql zotero WebDAV 同步失败 elasticsearch jenkins ansible playbook java-ee AI 爬虫 数据集 微信 微信分享 Image wxopensdk 嵌入式硬件 温湿度数据上传到服务器 Arduino HTTP vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 html 集成学习 集成测试 银河麒麟服务器操作系统 系统激活 sql KingBase 博客 uni-app oceanbase rc.local 开机自启 systemd 麒麟 银河麒麟 kylin v10 麒麟 v10 conda HarmonyOS Next 开源 spring av1 电视盒子 机顶盒ROM 魔百盒刷机 spring boot 3d 数学建模 tomcat postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 向日葵 ESP32 LDAP express 实时音视频 maven intellij idea 腾讯云 nuxt3 vue3 dubbo bash .netcore Docker Compose docker compose docker-compose .net openEuler unity3d 物联网 Qwen2.5-coder 离线部署 gitlab 软件工程 低代码 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 僵尸进程 jmeter 软件测试 HCIE 数通 大模型微调 kubernetes VMware安装Ubuntu Ubuntu安装k8s k8s mysql离线安装 ubuntu22.04 mysql8.0 企业微信 Linux24.04 deepin gateway Clion Nova ResharperC++引擎 Centos7 远程开发 pillow live555 rtsp rtp json html5 firefox sqlserver kamailio sip VoIP 大数据 大数据平台 统信 国产操作系统 虚拟机安装 WSL win11 无法解析服务器的名称或地址 YOLOv12 程序人生 代码调试 ipdb asm 多线程服务器 Linux网络编程 springsecurity6 oauth2 授权服务器 token sas DeepSeek-R1 API接口 mongodb visualstudio list 数据结构 prometheus gitee 微服务 springcloud kvm 无桌面 命令行 串口服务器 matlab 嵌入式 linux驱动开发 arm开发 Cline YOLOv8 NPU Atlas800 A300I pro asi_bench GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 apache AIGC RAGFLOW RAG 检索增强生成 文档解析 大模型垂直应用 JAVA IDEA Java 命令 策略模式 单例模式 Linux 进程信号 Google pay Apple pay 压力测试 职场和发展 网工 压测 ECS ssrf 失效的访问控制 camera Arduino 电子信息 GCC Linux环境 宕机切换 服务器宕机 1024程序员节 Unity Dedicated Server Host Client 无头主机 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 elk idm 医疗APP开发 app开发 课程设计 debian protobuf 序列化和反序列化 安装 windows日志 跨域 vue vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 数据挖掘 gpu算力 virtualenv arm 大语言模型 华为od 机器人 视觉检测 设置代理 实用教程 自动化测试 性能测试 功能测试 游戏程序 ios PVE 自动驾驶 能力提升 面试宝典 技术 IT信息化 环境迁移 linux 命令 sed 命令 thingsboard postgresql 强制清理 强制删除 mac废纸篓 权限 XFS xfs文件系统损坏 I_O error 直播推流 Ark-TS语言 unix git npm iot midjourney AI写作 相差8小时 UTC 时间 netty WebUI DeepSeek V3 DeepSeek AI大模型 xml rpc 远程过程调用 Windows环境 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 中间件 FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 svn FTP服务器 状态管理的 UDP 服务器 Arduino RTOS yum 服务器配置 生物信息学 zabbix 驱动开发 mcu gitea jar risc-v 负载均衡 重启 排查 系统重启 日志 原因 Wi-Fi 计算机 干货分享 黑客工具 密码爆破 远程工作 web Socket gradle DNS Spring Security 编辑器 鸿蒙系统 microsoft 技术共享 VMware安装mocOS VMware macOS系统安装 jupyter C# MQTTS 双向认证 emqx Invalid Host allowedHosts 远程连接 rdp 实验 https r语言 数据可视化 ip命令 新增网卡 新增IP 启动网卡 统信UOS bonding 链路聚合 执法记录仪 智能安全帽 smarteye tailscale derp derper 中转 矩阵 线性代数 电商平台 UOS 统信操作系统 SysBench 基准测试 minio C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 图形化界面 ISO镜像作为本地源 云电竞 云电脑 todesk Erlang OTP gen_server 热代码交换 事务语义 webrtc 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 cursor 音乐服务器 Navidrome 音流 MCP server C/S LLM transformer ping++ 产品经理 agi wsl2 wsl 游戏服务器 Minecraft DOIT 四博智联 Open WebUI 宝塔面板 部署 devops ci/cd pip H3C ESXi Dell HPE 联想 浪潮 iDRAC R720xd selete 高级IO 命名管道 客户端与服务端通信 多层架构 解耦 freebsd Linux PID pppoe radius 信息与通信 kafka 系统安全 Docker Hub docker pull 镜像源 daemon.json Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 远程桌面 gaussdb eureka 测试用例 shell 磁盘监控 kind 华为云 react next.js 部署next.js QQ 聊天室 spring cloud c 前后端分离 ocr 华为认证 网络工程师 AI agent 硬件架构 系统架构 云服务 智能手机 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 剧本 file server http server web server muduo X11 Xming 小程序 efficientVIT YOLOv8替换主干网络 TOLOv8 tcpdump 宠物 毕业设计 免费学习 宠物领养 宠物平台 王者荣耀 小艺 Pura X excel cnn GoogLeNet 弹性计算 虚拟化 KVM 计算虚拟化 弹性裸金属 mariadb MacMini Mac 迷你主机 mini Apple windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 5G 3GPP 卫星通信 WSL2 交换机 硬件 设备 GPU PCI-Express Agent 监控k8s集群 集群内prometheus 阻塞队列 生产者消费者模型 服务器崩坏原因 网站搭建 serv00 jetty undertow Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 grafana 远程登录 telnet 云服务器 裸金属服务器 弹性裸金属服务器 p2p VR手套 数据手套 动捕手套 动捕数据手套 MNN Qwen ip ui vmware 卡死 openwrt NAS Termux Samba SSH 银河麒麟桌面操作系统 Kylin OS 国产化 DeepSeek行业应用 Heroku 网站部署 xss 网络结构图 游戏机 技能大赛 hugo Netty 即时通信 NIO 7z SWAT 配置文件 服务管理 网络共享 HTTP 服务器控制 ESP32 DeepSeek 输入法 ruoyi linux环境变量 vasp安装 gpt-3 文心一言 远程 执行 sshpass 操作 AutoDL AI作画 IIS服务器 IIS性能 日志监控 半虚拟化 硬件虚拟化 Hypervisor wireshark 显示过滤器 ICMP Wireshark安装 pygame eNSP 网络规划 VLAN 企业网络 micropython esp32 mqtt 思科模拟器 思科 Cisco asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 C语言 算力 程序员 ArcTS 登录 ArcUI GridItem arkUI k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm googlecloud sqlite perf TCP服务器 qt项目 qt项目实战 qt教程 openssl 密码学 模拟退火算法 dify 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP chrome devtools selenium chromedriver 其他 网络用户购物行为分析可视化平台 大数据毕业设计 服务器管理 配置教程 服务器安装 网站管理 数据分析 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 根服务器 clickhouse 社交电子 数据库系统 nvidia 客户端 EMQX MQTT 通信协议 hibernate openstack Xen 虚拟机 银河麒麟高级服务器 外接硬盘 Kylin 工业4.0 Cursor chfs ubuntu 16.04 漏洞 nac 802.1 portal 同步 备份 建站 安全威胁分析 微信开放平台 微信公众号配置 vscode 1.86 laravel Logstash 日志采集 大模型入门 大模型教程 直流充电桩 充电桩 语法 IPMI TRAE junit 小智AI服务端 xiaozhi TTS Playwright rust腐蚀 W5500 OLED u8g2 需求分析 规格说明书 bug 豆瓣 追剧助手 迅雷 nas 内存 系统 黑苹果 微信小程序 小游戏 五子棋 支付 微信支付 开放平台 sdkman DevEco Studio 网络穿透 springboot 火绒安全 Nuxt.js Xterminal RAID RAID技术 磁盘 存储 服务器繁忙 备选 网站 api 调用 示例 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 cuda cudnn AD域 vSphere vCenter 软件定义数据中心 sddc ceph 反向代理 致远OA OA服务器 服务器磁盘扩容 threejs 3D okhttp CORS CPU 主板 电源 网卡 雨云 NPS 政务 分布式系统 监控运维 Prometheus Grafana 飞书 dns uniapp alias unalias 别名 aws 恒源云 Dify 源码 消息队列 echarts 传统数据库升级 银行 LLMs 边缘计算 智能硬件 深度求索 私域 知识库 服务器数据恢复 数据恢复 存储数据恢复 北亚数据恢复 oracle数据恢复 oneapi rocketmq 缓存 hive Hive环境搭建 hive3环境 Hive远程模式 pgpool XCC Lenovo etcd 数据安全 RBAC 田俊楠 移动云 MS Materials centos-root /dev/mapper yum clean all df -h / du -sh 业界资讯 鲲鹏 京东云 frp code-server mosquitto Headless Linux 腾讯云大模型知识引擎 flink SSL 域名 华为机试 C++ Python skynet 报错 安全架构 AISphereButler 自定义客户端 SAS embedding flash-attention outlook 框架搭建 回显服务器 UDP的API使用 armbian u-boot springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 LORA NLP Reactor 设计模式 remote-ssh Trae IDE AI 原生集成开发环境 Trae AI ukui 麒麟kylinos openeuler EasyConnect 飞牛NAS 飞牛OS MacBook Pro RustDesk自建服务器 rustdesk服务器 docker rustdesk 黑客技术 URL ftp VPS pyqt Ubuntu Server Ubuntu 22.04.5 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 tcp ux 多线程 vscode1.86 1.86版本 ssh远程连接 prompt OD机试真题 华为OD机试真题 服务器能耗统计 SSE 多进程 open Euler dde RTMP 应用层 LLM Web APP Streamlit hadoop big data opensearch helm 服务器主板 AI芯片 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 MI300x 孤岛惊魂4 WebRTC gpt 开发环境 SSL证书 sysctl.conf vm.nr_hugepages 可信计算技术 网络攻击模型 adobe 单一职责原则 网络编程 聊天服务器 套接字 TCP n8n 工作流 workflow firewalld IPMITOOL BMC 硬件管理 opcua opcda KEPServer安装 open webui xrdp string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap TrinityCore 魔兽世界 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 iftop 网络流量监控 Ubuntu 24.04.1 轻量级服务器 NFS redhat 繁忙 解决办法 替代网站 汇总推荐 AI推理 tidb GLIBC pdf asp.net大文件上传下载 群晖 文件分享 dba iis VSCode odoo 服务器动作 Server action 雨云服务器 FTP 服务器 崖山数据库 YashanDB gcc g++ g++13 iphone Cookie VMware创建虚拟机 视频编解码 源码剖析 rtsp实现步骤 流媒体开发 zookeeper 目标跟踪 OpenVINO 推理应用 服务器部署ai模型 rsyslog Anolis nginx安装 环境安装 linux插件下载 saltstack cpu 实时 使用 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 安卓 开机自启动 毕设 easyui langchain raid5数据恢复 磁盘阵列数据恢复 Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer 僵尸世界大战 游戏服务器搭建 远程控制 远程看看 远程协助 银河麒麟操作系统 ue4 着色器 ue5 虚幻 硬件工程 嵌入式实习 ipython yum源切换 更换国内yum源 bot Docker 三级等保 服务器审计日志备份 v10 软件 文件系统 路径解析 bootstrap ecmascript nextjs reactjs 软考 流式接口 css 本地部署 架构与原理 联想开天P90Z装win10 MacOS录屏软件 Kylin-Server 交叉编译 多个客户端访问 IO多路复用 TCP相关API 蓝桥杯 x64 SIGSEGV xmm0 miniapp 真机调试 调试 debug 断点 网络API请求调试方法 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? apt 国内源 网卡的名称修改 eth0 ens33 triton 模型分析 tensorflow 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors AI-native Docker Desktop CH340 串口驱动 CH341 uart 485 图像处理 less 游戏引擎 指令 防火墙 NAT转发 NAT Server 办公自动化 自动化生成 pdf教程 bat aarch64 编译安装 HPC Deepseek-R1 私有化部署 推理模型 李心怡 bcompare Beyond Compare webstorm 模拟器 教程 su sudo xpath定位元素 dash 正则表达式 Windows crosstool-ng db 强化学习 无人机 常用命令 文本命令 目录命令 python3.11 树莓派 VNC Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 相机 SSH 服务 SSH Server OpenSSH Server 自动化任务管理 linux安装配置 企业网络规划 华为eNSP 信创 信创终端 中科方德 kali 共享文件夹 软链接 硬链接 css3 sentinel visual studio code EMUI 回退 降级 升级 DenseNet mamba fd 文件描述符 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 log4j 中兴光猫 换光猫 网络桥接 自己换光猫 虚拟显示器 ArkUI 多端开发 智慧分发 应用生态 鸿蒙OS cmos vr 单元测试 ruby 我的世界 我的世界联机 数码 灵办AI UDP 链表 我的世界服务器搭建 ros 加解密 Yakit yaklang Xinference RAGFlow Ubuntu共享文件夹 共享目录 Linux共享文件夹 eclipse ubuntu24 vivado24 带外管理 edge浏览器 免费域名 域名解析 元服务 应用上架 服务器时间 流量运营 docker命令大全 换源 Debian DocFlow mq KylinV10 麒麟操作系统 Vmware trae perl fstab iBMC UltraISO lua k8s集群资源管理 云原生开发 Linux的权限 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 域名服务 DHCP 符号链接 配置 dns是什么 如何设置电脑dns dns应该如何设置 影刀 #影刀RPA# 监控k8s 监控kubernetes 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 音乐库 飞牛 Python基础 Python教程 Python技巧 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 glibc rustdesk 本地部署AI大模型 deekseek ragflow LInux cd 目录切换 分析解读 Claude 实习 大模型面经 大模型学习 AnythingLLM AnythingLLM安装 Unity插件 iventoy VmWare OpenEuler idea react native CrewAI rime qemu libvirt 个人博客 figma WebVM 基础环境 流水线 脚本式流水线 信号 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 双系统 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK 并查集 leetcode 金仓数据库 2025 征文 数据库平替用金仓 信号处理 问题解决 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 显示管理器 lightdm gdm HarmonyOS USB网络共享 grub 版本升级 扩容 ssh远程登录 游戏开发 程序员创富 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 浏览器开发 AI浏览器 ssh漏洞 ssh9.9p2 CVE-2025-23419 自动化编程 docker run 数据卷挂载 交互模式 程序 性能调优 安全代理 etl win服务器架设 windows server ai小智 语音助手 ai小智配网 ai小智教程 esp32语音助手 diy语音助手 本地知识库部署 DeepSeek R1 模型 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 迁移指南 minecraft llama.cpp ros2 moveit 机器人运动 软件构建 proxy模式 烟花代码 烟花 元旦 rclone AList webdav fnOS matplotlib Kali Linux的基础指令 keepalived sonoma 自动更新 查询数据库服务IP地址 SQL Server 分布式训练 xshell termius iterm2 软件卸载 系统清理 dity make 环境配置 safari 实战案例 searxng Radius 历史版本 下载 服务网格 istio Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 状态模式 SVN Server tortoise svn xcode docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 合成模型 扩散模型 图像生成 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 can 线程池 序列化反序列化 firewall HAProxy UOS1070e VS Code ABAP 线程 cfssl TCP协议 抗锯齿 物联网开发 milvus OpenHarmony AD 域管理 QT 5.12.12 QT开发环境 Ubuntu18.04 GRUB引导 Linux技巧 linux上传下载 健康医疗 互联网医院 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 hexo c/c++ 串口 SEO P2P HDLC MVS 海康威视相机 用户缓冲区 模拟实现 sequoiaDB PX4 ROS 捆绑 链接 谷歌浏览器 youtube google gmail 内网服务器 内网代理 内网通信 编程 性能分析 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 图形渲染 实时互动 autodl 虚拟局域网 prometheus数据采集 prometheus数据模型 prometheus特点 cocoapods AI代码编辑器 SenseVoice 互信 毕昇JDK yaml Ultralytics 可视化 OpenSSH yolov8 混合开发 JDK 语音识别 regedit 开机启动 显卡驱动 大模型应用 版本 容器技术 webgl wpf 安防软件 IPv4 子网掩码 公网IP 私有IP 端口测试 SSH 密钥生成 SSH 公钥 私钥 生成 主从复制 CDN jina 匿名管道 考研 onlyoffice 在线office 金融 EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 seatunnel 基础入门 nfs 信息可视化 网页设计 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 私有化 composer iperf3 带宽测试 产测工具框架 IMX6ULL 管理框架 Ubuntu22.04 开发人员主页 trea wsgiref Web 服务器网关接口 MySql 昇腾 npu Jellyfin 大大通 第三代半导体 碳化硅 存储维护 NetApp存储 EMC存储 开发 Vmamba docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 云桌面 微软 AD域控 证书服务器 ai工具 TrueLicense epoll java-rocketmq 做raid 装系统 ardunio BLE 代码 对比 工具 meld DiffMerge lio-sam SLAM uv h.264 移动魔百盒 超融合 USB转串口 键盘 harmonyOS面试题 邮件APP 免费软件 项目部署到linux服务器 项目部署过程 CVE-2024-7347 HiCar CarLife+ CarPlay QT RK3588 IO模型 CLion Node-Red 编程工具 流编程 wps cpp-httplib web3 ubuntu24.04.1 代理服务器 curl wget 端口 查看 ss 智能音箱 智能家居 fast deployment daemonset statefulset cronjob 读写锁 AI Agent 字节智能运维 rnn IMM deepseek r1 SRS 流媒体 直播 MQTT协议 消息服务器 arcgis make命令 makefile文件 粘包问题 vpn spark HistoryServer Spark YARN jobhistory IM即时通讯 剪切板对通 HTML FORMAT pyautogui sqlite3 IMX317 MIPI H265 VCU MacOS ShenTong rag ragflow 源码启动 Typore 运维监控 镜像 知识图谱 查看显卡进程 fuser GIS 遥感 WebGIS 阿里云ECS anaconda swoole navicat ldap Linux find grep 钉钉 代理 飞牛nas fnos 内网环境 DeepSeek r1 OpenManus 抓包工具 宝塔 CentOS 网络建设与运维 热榜 docker部署Python mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 MDK 嵌入式开发工具 论文笔记 sublime text docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 离线部署dify gnu hosts 嵌入式Linux IPC nlp 搭建个人相关服务器 推荐算法 智能电视 HarmonyOS NEXT 原生鸿蒙 kotlin 欧标 OCPP neo4j vllm 服务器正确解析请求体 WLAN deep learning yum换源 IO CentOS Stream 风扇控制软件 网络爬虫 ubuntu20.04 开机黑屏 Qwen2.5-VL 沙盒 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR 虚幻引擎 大模型推理 论文阅读 Redis Desktop 嵌入式系统开发 磁盘清理 powerpoint 数据仓库 数据库开发 database 网络搭建 神州数码 神州数码云平台 云平台 PPI String Cytoscape CytoHubba js 人工智能生成内容 DBeaver kerberos 拓扑图 word 多路转接 代码托管服务 鸿蒙开发 移动开发 top Linux top top命令详解 top命令重点 top常用参数 visual studio 项目部署 聚类 ranger MySQL8.0 dock 加速 渗透 本地化部署 kernel 玩机技巧 软件分享 软件图标 seleium 达梦 DM8 软负载 自学笔记 小米 澎湃OS Android 西门子PLC 通讯 远程服务 conda配置 conda镜像源 稳定性 看门狗 大模型部署 rpa ArkTs ArtTS Mac内存不够用怎么办 Attention