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

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

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

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