当前位置: 首页 > news >正文

Django进阶

1.orm

1.1 基本操作

orm,关系对象映射。

类      --> SQL -->     表
对象    --> SQL -->     数据

特点:开发效率高、执行效率低( 程序写的垃圾SQL )。

编写ORM操作的步骤:

  • settings.py,连接数据库

    DATABASES = {'default': {'ENGINE': 'django.db.backends.sqlite3','NAME': BASE_DIR / 'db.sqlite3',}
    }
    
  • settings.py,注册app

    INSTALLED_APP = [..."app01.apps.App01Config"
    ]
    
  • 编写models.类

    class UserInfo(models.Model):.........
    
  • 执行命令

    python manage.py makemigrations    # 找到所有已注册的app中的models.py中的类读取 -> migrations配置
    python manage.py migrate           # 读取已注册的app下的migrations配置 -> SQL语句  -> 同步数据库
    

1.2 连接数据库

DATABASES = {'default': {'ENGINE': 'django.db.backends.sqlite3','NAME': BASE_DIR / 'db.sqlite3',}
}
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'xxxxxxxx',  # 数据库名字'USER': 'root','PASSWORD': 'root123','HOST': '127.0.0.1',  # ip'PORT': 3306,}
}

项目连接MySQL:

  • 安装MySQL & 启动MySQL服务

  • 手动创建数据库

  • django的settings.py配置

    DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'xxxxxxxx',  # 数据库名字'USER': 'root','PASSWORD': 'root123','HOST': '127.0.0.1',  # ip'PORT': 3306,}
    }
    
  • 安装第三方组件

    • pymysql

      pip install pymysql
      
      项目根目录/项目名目录/__init__.pyimport pymysqlpymysql.install_as_MySQLdb()
      
    • mysqlclient

      pip install mysqlclient
      
      电脑上先提前安装MySQL。
      

其他数据库:

DATABASES = {'default': {'ENGINE': 'django.db.backends.postgresql','NAME': 'mydatabase','USER': 'mydatabaseuser','PASSWORD': 'mypassword','HOST': '127.0.0.1','PORT': 5432,}
}# 需要 pip install psycopg2
DATABASES = {'default': {'ENGINE': 'django.db.backends.oracle','NAME': "xxxx",  # 库名"USER": "xxxxx",  # 用户名"PASSWORD": "xxxxx",  # 密码"HOST": "127.0.0.1",  # ip"PORT": 1521,  # 端口}
}
# 需要 pip install cx-Oracle

1.3 连接池

django默认内置没有数据库连接池 。

pymysql   -> 操作数据库
DBUtils   -> 连接池

https://pypi.org/project/django-db-connection-pool/

pip install django-db-connection-pool
DATABASES = {"default": {'ENGINE': 'dj_db_conn_pool.backends.mysql','NAME': 'day04',  # 数据库名字'USER': 'root','PASSWORD': 'root123','HOST': '127.0.0.1',  # ip'PORT': 3306,'POOL_OPTIONS': {'POOL_SIZE': 10,  # 最小'MAX_OVERFLOW': 10,  # 在最小的基础上,还可以增加10个,即:最大20个。'RECYCLE': 24 * 60 * 60,  # 连接可以被重复用多久,超过会重新创建,-1表示永久。'TIMEOUT':30, # 池中没有连接最多等待的时间。}}
}

注意:组件django-db-connection-pool不是特别厉害。拿了另外一个支持SQLAchemy数据库连接池的组件。

1.4 多数据库

django支持项目连接多个数据库。

DATABASES = {"default": {'ENGINE': 'dj_db_conn_pool.backends.mysql','NAME': 'day05db',  # 数据库名字'USER': 'root','PASSWORD': 'root123','HOST': '127.0.0.1',  # ip'PORT': 3306,'POOL_OPTIONS': {'POOL_SIZE': 10,  # 最小'MAX_OVERFLOW': 10,  # 在最小的基础上,还可以增加10个,即:最大20个。'RECYCLE': 24 * 60 * 60,  # 连接可以被重复用多久,超过会重新创建,-1表示永久。'TIMEOUT': 30,  # 池中没有连接最多等待的时间。}},"bak": {'ENGINE': 'dj_db_conn_pool.backends.mysql','NAME': 'day05bak',  # 数据库名字'USER': 'root','PASSWORD': 'root123','HOST': '127.0.0.1',  # ip'PORT': 3306,'POOL_OPTIONS': {'POOL_SIZE': 10,  # 最小'MAX_OVERFLOW': 10,  # 在最小的基础上,还可以增加10个,即:最大20个。'RECYCLE': 24 * 60 * 60,  # 连接可以被重复用多久,超过会重新创建,-1表示永久。'TIMEOUT': 30,  # 池中没有连接最多等待的时间。}},
}

1.4.1 读写分离

192.168.1.2       default master   [写]组件
192.168.2.12      bak slave    [读]
  • 生成数据库表

    python manage.py makemigrations    # 找到所有已注册的app中的models.py中的类读取 -> migrations配置python manage.py migrate
    python manage.py migrate --database=default
    python manage.py migrate --database=bak
    
  • 后续再进行开发时

    models.UserInfo.objects.using("default").create(title="武沛齐")models.UserInfo.objects.using("bak").all()
    
  • 编写router类,简化【后续再进行开发时】

    class DemoRouter(object):def db_for_read(...):return "bak"def db_for_write(...):return "default"
    
    router = ["DemoRouter"]
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lhY2Qz9B-1691504274637)(assets/image-20220710104821310.png)]

1.4.2 分库(多个app ->多数据库)

100张表,50表-A数据库【app02】;50表-B数据库【app02】。

  • app01/models

    from django.db import modelsclass UserInfo(models.Model):title = models.CharField(verbose_name="标题", max_length=32)
  • app02/models

    from django.db import modelsclass Role(models.Model):title = models.CharField(verbose_name="标题", max_length=32)
    
  • 命令

    python manage.py makemigrations
    
    python manage.py migrate app01 --database=default
    
    python manage.py migrate app02 --database=bak
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hql4Q7xd-1691504274638)(assets/image-20220710105925961.png)]

  • 读写操作

    from django.shortcuts import render, HttpResponsefrom app01 import models as m1
    from app02 import models as m2def index(request):# app01中的操作 -> defaultv1 = m1.UserInfo.objects.all()print(v1)# app02中的操作 -> bakv2 = m2.Role.objects.using('bak').all()print(v2)return HttpResponse("返回")
    
  • router

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-i2zEQ9Rx-1691504274638)(assets/image-20220710110711518.png)]

1.4.3 分库(单app)

100张表,50表-A数据库;50表-B数据库。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IlBVSYSN-1691504274638)(assets/image-20220710111923985.png)]

from django.shortcuts import render, HttpResponsefrom app01 import models as m1def index(request):# app01中的操作 -> defaultv1 = m1.UserInfo.objects.all()print(v1)# app01中的操作 -> bakv2 = m1.Role.objects.using('bak').all()print(v2)return HttpResponse("返回")

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gAxGnF3B-1691504274639)(assets/image-20220710112344681.png)]

1.4.4 注意事项

  • 分库,表拆分到不用数据库。

    一定不要跨数据库做关联  -> django不支持怎么办?
    尽可能的将有关联的表放在一个库中。
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-j1qIs9kd-1691504274639)(assets/image-20220710112908647.png)]

  • 为什么表拆分到不同的库?

1.5 表关系

  • 单表

    class Role(models.Model):title = models.CharField(verbose_name="标题", max_length=32)
    
  • 一对多

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sJWVEnZZ-1691504274639)(assets/image-20220710115245095.png)]

  • 多对多
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8iI1KLWA-1691504274640)(assets/image-20220710115902277.png)]

    如果关系表中只有3列。

    class Boy(models.Model):"""1   杰森斯坦森2   汤普森"""name = models.CharField(verbose_name="标题", max_length=32, unique=True)b = models.ManyToManyField(to="Girl")class Girl(models.Model):"""1   alex2   苑昊"""name = models.CharField(verbose_name="标题", max_length=32, unique=True)
    
    class Boy(models.Model):"""1   杰森斯坦森2   汤普森"""name = models.CharField(verbose_name="标题", max_length=32, unique=True)class Girl(models.Model):"""1   alex2   苑昊"""name = models.CharField(verbose_name="标题", max_length=32, unique=True)b = models.ManyToManyField(to="Boy")
    
    class Boy(models.Model):name = models.CharField(verbose_name="标题", max_length=32, unique=True)class Girl(models.Model):name = models.CharField(verbose_name="标题", max_length=32, unique=True)class B2G(models.Model):bid = models.ForeignKey(to="Boy", on_delete=models.CASCADE)gid = models.ForeignKey(to="Girl", on_delete=models.CASCADE)address = models.CharField(verbose_name="地点", max_length=32)
    
  • 一对一

    表,100列     ->  50A表      50B表博客园为例:- 注册,用户名、密码,无法创建博客- 开通博客  地址/
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qIyKxHPs-1691504274640)(assets/image-20220710121216875.png)]

1.6 数据操作

  • 单表

    class Role(models.Model):title = models.CharField(verbose_name="标题", max_length=32)
    
    # obj1 = models.Role.objects.create(title="管理员", od=1)
    # obj2 = models.Role.objects.create(**{"title": "管理员", "od": 1})# 内存 -> save
    # obj = models.Role(title="客户", od=1)
    # obj.od = 100
    # obj.save()# obj = models.Role(**{"title": "管理员", "od": 1})
    # obj.od = 100
    # obj.save()
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9CzBzAyO-1691504274640)(assets/image-20220710143537101.png)]

    # models.Role.objects.all().delete()
    models.Role.objects.filter(title="管理员").delete()
    
    models.Role.objects.all().update(od=99)
    models.Role.objects.filter(id=7).update(od=99, title="管理员")
    models.Role.objects.filter(id=7).update(**{"od": 99, "title": "管理员"})
    
    # QuerySet = [obj, obj]
    v1 = models.Role.objects.all()
    for obj in v1:print(obj, obj.id, obj.title, obj.od)# QuerySet = []
    # v2 = models.Role.objects.filter(od=99, id=99)
    v2 = models.Role.objects.filter(**{"od": 99, "id": 99})
    for obj in v2:print(obj, obj.id, obj.title, obj.od)v3 = models.Role.objects.filter(id=99)
    print(v3.query)v3 = models.Role.objects.filter(id__gt=2)
    print(v3.query)v3 = models.Role.objects.filter(id__gte=2)
    print(v3.query)v3 = models.Role.objects.filter(id__lt=2)
    print(v3.query)v3 = models.Role.objects.filter(id__in=[11, 22, 33])
    print(v3.query)v3 = models.Role.objects.filter(title__contains="户")
    print(v3.query)v3 = models.Role.objects.filter(title__startswith="户")
    print(v3.query)v3 = models.Role.objects.filter(title__isnull=True)
    print(v3.query)
    
    v3 = models.Role.objects.filter(id=99)
    print(v3.query)
    # 不等于
    v3 = models.Role.objects.exclude(id=99).filter(od=88)
    print(v3.query)
    
    # queryset=[obj,obj]
    v3 = models.Role.objects.filter(id=99)# queryset=[{'id': 6, 'title': '客户'}, {'id': 7, 'title': '客户'}]
    v4 = models.Role.objects.filter(id__gt=0).values("id", 'title')# QuerySet = [(6, '客户'), (7, '客户')]
    v5 = models.Role.objects.filter(id__gt=0).values_list("id", 'title')
    print(v5[0])
    
    v6 = models.Role.objects.filter(id__gt=0).first()
    # print(v6)  # 对象v7 = models.Role.objects.filter(id__gt=10).exists()
    print(v7)  # True/False
    
    # asc
    v8 = models.Role.objects.filter(id__gt=0).order_by("id")# id desc  od asc
    v9 = models.Role.objects.filter(id__gt=0).order_by("-id", 'od')
    
  • 一对多

    class Depart(models.Model):""" 部门 """title = models.CharField(verbose_name="标题", max_length=32)class Admin(models.Model):name = models.CharField(verbose_name="姓名", max_length=32)pwd = models.CharField(verbose_name="密码", max_length=32)depart = models.ForeignKey(verbose_name="部门", to="Depart", on_delete=models.CASCADE)
    
    models.Admin.objects.create(name='武沛齐1', pwd='123123123', depart_id=2)
    # models.Admin.objects.create(**{..})obj = models.Depart.objects.filter(id=2).first()
    models.Admin.objects.create(name='武沛齐2', pwd='123123123', depart=obj)
    models.Admin.objects.create(name='武沛齐2', pwd='123123123', depart_id=obj.id)
    
    # filter()   # 当前表的字段 + depart__字段    -> 连表和条件# 找到部门id=3的所有的员工,删除
    # models.Admin.objects.filter(depart_id=3).delete()# 删除销售部的所有员工
    # obj = models.Depart.objects.filter(title="销售部").first()
    # models.Admin.objects.filter(depart_id=obj.id).delete()# models.Admin.objects.filter(depart__title="销售部", name='武沛齐').delete()
    
    # 1. select * from admin    					queryset=[obj,obj,]
    v1 = models.Admin.objects.filter(id__gt=0)
    for obj in v1:print(obj.name, obj.pwd, obj.id, obj.depart_id)# 2. select * from admin inner join depart      queryset=[obj,obj,]
    v2 = models.Admin.objects.filter(id__gt=0).select_related("depart")
    for obj in v2:print(obj.name, obj.pwd, obj.id, obj.depart_id, obj.depart.title)# 3. select id,name.. from admin inner join depart      queryset=[{},{}]
    v3 = models.Admin.objects.filter(id__gt=0).values("id", 'name', 'pwd', "depart__title")
    print(v3)# 4. select id,name.. from admin inner join depart      queryset=[(),()]
    v4 = models.Admin.objects.filter(id__gt=0).values_list("id", 'name', 'pwd', "depart__title")
    print(v4)
    
    # 查询
    # models.Admin.objects.filter(id=2).update(name='xxx', pwd='xxxx')
    # models.Admin.objects.filter(name="武沛齐").update(depart_id=2)# models.Admin.objects.filter(id=2).update(depart__title="技术部")  -> 只能更新自己表字段
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hFndAp7E-1691504274640)(assets/image-20220710164040495.png)]

  • 多对多

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R0kfJTaS-1691504274641)(assets/image-20220710170440957.png)]

    from django.db import modelsclass Boy(models.Model):name = models.CharField(verbose_name="姓名", max_length=32, db_index=True)class Girl(models.Model):name = models.CharField(verbose_name="姓名", max_length=32, db_index=True)class B2G(models.Model):bid = models.ForeignKey(to="Boy", on_delete=models.CASCADE)gid = models.ForeignKey(to="Girl", on_delete=models.CASCADE)address = models.CharField(verbose_name="地点", max_length=32)
    
    def index(request):# models.Boy.objects.create(name="宝强")# models.Boy.objects.create(name="羽凡")# models.Boy.objects.create(name="乃亮")## models.Girl.objects.bulk_create(#     objs=[models.Girl(name="小路"), models.Girl(name="百合"), models.Girl(name="马蓉")],#     batch_size=3# )# 创建关系# models.B2G.objects.create(bid_id=1, gid_id=3, address="北京")# models.B2G.objects.create(bid_id=1, gid_id=2, address="北京")# models.B2G.objects.create(bid_id=2, gid_id=2, address="北京")# models.B2G.objects.create(bid_id=2, gid_id=1, address="北京")# b_obj = models.Boy.objects.filter(name='宝强').first()# g_object = models.Girl.objects.filter(name="小路").first()# models.B2G.objects.create(bid=b_obj, gid=g_object, address="北京")# 1.宝强都与谁约会。# queyset=[obj,obj,obj]# q = models.B2G.objects.filter(bid__name='宝强').select_related("gid")# for item in q:#     print(item.id, item.address, item.bid.name, item.gid.name)# q = models.B2G.objects.filter(bid__name='宝强').values("id", 'bid__name', 'gid__name')# for item in q:#     print(item['id'], item['bid__name'], item['gid__name'])# 2.百合 都与谁约会。# q = models.B2G.objects.filter(gid__name='百合').values("id", 'bid__name', 'gid__name')# for item in q:#     print(item['id'], item['bid__name'], item['gid__name'])# 3.删除# models.B2G.objects.filter(id=1).delete()# models.Boy.objects.filter(id=1).delete()return HttpResponse("返回")
    
  • 一对一
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZqGIYz02-1691504274641)(assets/image-20220710173043956.png)]

2.cookie和session

2.1 cookie

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dZpX2Ofe-1691504274641)(assets/image-20220710174352897.png)]

127.0.0.1       v1.wupeiqi.com
127.0.0.1       v2.wupeiqi.com

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u9mqo9nb-1691504274641)(assets/image-20220710175925008.png)]

2.2 配置session

  • 文件版

    MIDDLEWARE = ['django.middleware.security.SecurityMiddleware','django.contrib.sessions.middleware.SessionMiddleware','django.middleware.common.CommonMiddleware','django.middleware.csrf.CsrfViewMiddleware',# 'django.contrib.auth.middleware.AuthenticationMiddleware',# 'django.contrib.messages.middleware.MessageMiddleware','django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]# session
    SESSION_ENGINE = 'django.contrib.sessions.backends.file'
    SESSION_FILE_PATH = 'xxxx' SESSION_COOKIE_NAME = "sid"  # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
    SESSION_COOKIE_PATH = "/"  # Session的cookie保存的路径
    SESSION_COOKIE_DOMAIN = None  # Session的cookie保存的域名
    SESSION_COOKIE_SECURE = False  # 是否Https传输cookie
    SESSION_COOKIE_HTTPONLY = True  # 是否Session的cookie只支持http传输
    SESSION_COOKIE_AGE = 1209600  # Session的cookie失效日期(2周)SESSION_EXPIRE_AT_BROWSER_CLOSE = False  # 是否关闭浏览器使得Session过期
    SESSION_SAVE_EVERY_REQUEST = True  # 是否每次请求都保存Session,默认修改之后才保存
    
  • 数据库

    INSTALLED_APPS = [# 'django.contrib.admin',# 'django.contrib.auth',# 'django.contrib.contenttypes','django.contrib.sessions',# 'django.contrib.messages','django.contrib.staticfiles',"app01.apps.App01Config",
    ]MIDDLEWARE = ['django.middleware.security.SecurityMiddleware','django.contrib.sessions.middleware.SessionMiddleware','django.middleware.common.CommonMiddleware','django.middleware.csrf.CsrfViewMiddleware',# 'django.contrib.auth.middleware.AuthenticationMiddleware',# 'django.contrib.messages.middleware.MessageMiddleware','django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]# session
    SESSION_ENGINE = 'django.contrib.sessions.backends.db'SESSION_COOKIE_NAME = "sid"  # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
    SESSION_COOKIE_PATH = "/"  # Session的cookie保存的路径
    SESSION_COOKIE_DOMAIN = None  # Session的cookie保存的域名
    SESSION_COOKIE_SECURE = False  # 是否Https传输cookie
    SESSION_COOKIE_HTTPONLY = True  # 是否Session的cookie只支持http传输
    SESSION_COOKIE_AGE = 1209600  # Session的cookie失效日期(2周)SESSION_EXPIRE_AT_BROWSER_CLOSE = False  # 是否关闭浏览器使得Session过期
    SESSION_SAVE_EVERY_REQUEST = True  # 是否每次请求都保存Session,默认修改之后才保存
    
  • 缓存

    INSTALLED_APPS = [# 'django.contrib.admin',# 'django.contrib.auth',# 'django.contrib.contenttypes',# 'django.contrib.sessions',# 'django.contrib.messages','django.contrib.staticfiles',"app01.apps.App01Config",
    ]MIDDLEWARE = ['django.middleware.security.SecurityMiddleware','django.contrib.sessions.middleware.SessionMiddleware','django.middleware.common.CommonMiddleware','django.middleware.csrf.CsrfViewMiddleware',# 'django.contrib.auth.middleware.AuthenticationMiddleware',# 'django.contrib.messages.middleware.MessageMiddleware','django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]# session
    SESSION_ENGINE = 'django.contrib.sessions.backends.cache'
    SESSION_CACHE_ALIAS = 'default' SESSION_COOKIE_NAME = "sid"  # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
    SESSION_COOKIE_PATH = "/"  # Session的cookie保存的路径
    SESSION_COOKIE_DOMAIN = None  # Session的cookie保存的域名
    SESSION_COOKIE_SECURE = False  # 是否Https传输cookie
    SESSION_COOKIE_HTTPONLY = True  # 是否Session的cookie只支持http传输
    SESSION_COOKIE_AGE = 1209600  # Session的cookie失效日期(2周)SESSION_EXPIRE_AT_BROWSER_CLOSE = False  # 是否关闭浏览器使得Session过期
    SESSION_SAVE_EVERY_REQUEST = True  # 是否每次请求都保存Session,默认修改之后才保存
    

3.缓存

  • 服务器 + redis安装启动

  • django

    • 安装连接redis包

      pip install django-redis
      
    • settings.py

      CACHES = {"default": {"BACKEND": "django_redis.cache.RedisCache","LOCATION": "redis://127.0.0.1:6379","OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient","CONNECTION_POOL_KWARGS": {"max_connections": 100}# "PASSWORD": "密码",}}
      }
      
    • 手动操作redis

      from django_redis import get_redis_connectionconn = get_redis_connection("default")
      conn.set("xx","123123")
      conn.get("xx")
      

相关文章:

Django进阶

1.orm 1.1 基本操作 orm,关系对象映射。 类 --> SQL --> 表 对象 --> SQL --> 数据特点:开发效率高、执行效率低( 程序写的垃圾SQL )。 编写ORM操作的步骤: settings.py,连…...

Linux系统服务管理

服务命令比较 操作 Linux 6 Linux7 服务开机自动启动 chkconfig --level 35 iptables on systemctl enable firewalld.service 服务器开机不自动启动 chkconfig --level 35 iptables off systemctl disable firewalld.service 加入自定义服务 chkconfig --add aaa s…...

C#之控制台版本得贪吃蛇

贪吃蛇小时候大家都玩过,具体步骤如下: 1.给游戏制造一个有限得空间。 2.生成墙壁,小蛇碰撞到墙壁或者咬到自己的尾巴,游戏结束。 3.生成随机的食物。 4.吃掉食物,增加自身的体长,并生成新的食物。 具体代码如下&…...

ffplay数据结构分析(一)

本文为相关课程的学习记录,相关分析均来源于课程的讲解,主要学习音视频相关的操作,对字幕的处理不做分析 下面我们对ffplay的相关数据结构进行分析,本章主要是对PacketQueue的讲解 struct MyAVPacketList和PacketQueue队列 ffp…...

JavaWeb学习|JSP相关内容

1.什么是JSP Java Server Pages: Java服务器端页面,也和Servlet一样,用于动态Web技术! 最大的特点: 。写JSP就像在写HTML 。区别: 。HTML只给用户提供静态的数据 。JSP页面中可以嵌入JAVA代码,为用户提供动态数据 JSP最终也会被转换成为一…...

Springboot后端通过路径映射获取本机图片资源

项目场景: 项目中对图片的处理与查看是必不可少的,本文将讲解如何通过项目路径来获取到本机电脑的图片资源 如图所示,在我的本机D盘的图片测试文件夹(文件夹名字不要有中文)下有一些图片, 我们要在浏览器上访问到这些图片&#…...

【IDEA + Spark 3.4.1 + sbt 1.9.3 + Spark MLlib 构建鸢尾花决策树分类预测模型】

决策树进行鸢尾花分类的案例 背景说明: 通过IDEA Spark 3.4.1 sbt 1.9.3 Spark MLlib 构建鸢尾花决策树分类预测模型,这是一个分类模型案例,通过该案例,可以快速了解Spark MLlib分类预测模型的使用方法。 依赖 ThisBuild /…...

亚马逊 EC2服务器下部署java环境

1. jdk 1.8 安装 1.1 下载jdk包 官网 Java Downloads | Oracle tar.gz 包 下载下来 1.2 本地连接 服务器 我用的是亚马逊的ec2 系统是 ubuntu 的 ssh工具是 Mobaxterm , 公有dns 创建实例时的秘钥 链接 Mobaxterm 因为使用的 ubuntu 所以登录的 名称 就是 ubuntu 然后 …...

CTF流量题解http1.pcapng

使用Wireshark工具打开流量文件http1.pcapng,如下图所示。 在过滤检索栏输入http,wireshark自动进行过滤。...

若依vue前端有全局用户信息变量吗

"若依"是一个基于SpringBoot和Vue的前后端分离的开源项目。在前端Vue部分,全局用户信息通常保存在Vuex中,Vuex是Vue.js的状态管理模式。它提供了一个集中式存储来管理所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生…...

什么是Milvus

原文出处:https://www.yii666.com/blog/393941.html 什么是Milvus Milvus 是一款云原生向量数据库,它具备高可用、高性能、易拓展的特点,用于海量向量数据的实时召回。 Milvus 基于 FAISS、Annoy、HNSW 等向量搜索库构建,核心是…...

如何快速实现三菱FX3U程序的无线下载?

1.系统概述 三菱PLC FX3u可以使用专用下载线通过计算机串口下载程序,同样也可以使用自制下载线缆,连接无线模块 DTD435M进行远程无线下载程序,计算机端采用RS232或者RS485 将计算机端与无线模块连接,PLC端同样使用RS232转RS485将…...

Flink源码之RPC

Flink是一个典型的Master/Slave分布式实时处理系统,分布式系统组件之间必然涉及通信,也即RPC,以下图展示Flink组件之间的关系: RPCGateWay 一般RPC框架可根据用户业务类生成客户端和服务器端通信底层代码,此时只需定…...

【LeetCode 75】第二十四题(2390)从字符串中移除星号

目录 题目: 示例: 分析: 代码运行结果: 题目: 示例: 分析: 题目给我们一个字符串,然后字符串中包含星号*,要求每个星号消除一个从星号左边起最近的一个字符&#xf…...

通向架构师的道路之weblogic的集群与配置

一、Weblogic的集群 还记得我们在第五天教程中讲到的关于Tomcat的集群吗? 两个tomcat做node即tomcat1, tomcat2,使用Apache HttpServer做请求派发。 现在看看WebLogic的集群吧,其实也差不多。 区别在于: Tomcat的集群的实现为两个物理上…...

SpringBoot 项目创建与运行

一、Spring Boot 1、什么是Spring Boot?为什么要学 Spring Boot Spring 的诞生是为了简化 Java 程序的开发的,而 Spring Boot 的诞生是为了简化 Spring 程序开发的。 Spring Boot 翻译一下就是 Spring 脚手架 盖房子的这个架子就是脚手架,…...

FOHEART H1数据手套:连接虚拟与现实,塑造智能交互新未来

在全新交互时代背景中,数据手套无疑是一种重要的科技产物。它不仅彻底改变了我们与虚拟世界的互动方式,更为我们提供了一种全新、更为直观的交互形式。 FOHEART H1数据手套结合了虚拟现实、手势识别等高新技术,用先进的传感技术和精准的数据…...

MyBatis学习笔记3

日志 1.日志工厂 如果一个数据库的操作,出现了异常,我们需要排错。日志就是最好的工具。 日志工厂:SLF4JLOG4J(掌握)LOG4J2JDK_LOGGINGCOMMONS_LOGGINGSTDOUT_LOGGING(掌握)NO_LOGGING 2.分页 减少数据…...

ES6学习-Symbol

Symbol 数据类型Symbol,表示独一无二的值。 对象的属性名可有两种类型,一种是原来的字符串,另一种是新增的 Symbol 类型 可以保证不与其他属性名产生冲突。 let s1 Symbol() let s2 Symbol() console.log(s1, s2, s1 s2)//Symbol() Sy…...

【Redis】使用Docker镜像配置集群时的Operation timed out问题

不知道有没有小伙伴跟我一样是使用的Docker镜像进行Redis集群案例模拟的(三台虚拟机确实带不动 ),然后我遇到了一个问题:Could not connect to Redis at 172.17.0.2:6379: Operation timed out 172.17.0.2是我其中一个Redis实例的…...

Java 生产初学常用注解

目录 0. 基础语法逻辑运算符继承抛出异常获取数据方式泛型 1. 接收前端数据(controller)mybatis1. QueryWrapper获取和赋值 2. service 层注解 3. Dao 层(与数据库交互)3.1 mybatis-plus中BaseMapper 4. ELK框架es配置sql参数logs…...

mousedown拖拽功能(vue3+ts)

因为项目有rem适配,使用第三方插件无法处理适配问题,所有只能自己写拖拽功能了 拖拽一般都会想到按下,移动,放开,但是本人亲测,就在div绑定一个按下事件就行了(在事件里面写另外两个事件&#x…...

【论文阅读】基于深度学习的时序异常检测——TransAD

系列文章链接 数据基础:多维时序数据集简介 论文一:2022 Anomaly Transformer:异常分数预测 论文二:2022 TransAD:异常分数预测 论文链接:TransAD.pdf 代码库链接:https://github.com/imperial…...

NLPCC 出版部分相关源码记录

目录 Download Unzip Author Title Affiliation Check number of tex Zip Rename Delete Download import requests from bs4 import BeautifulSoup# 登录网站并获取登录后的 session def login(username, password):login_url https://example.com/loginsession re…...

【Windbg】通过网络调试windows内核

环境 windows版本:win10_x64 1901 windbg版本:1.2306.12001.0 HOST 1、windbg软件设置。 点击菜单文件,然后如下图操作。 2、等待连接。 ************* Waiting for Debugger Extensions Gallery to Initialize **************>>&…...

代码随想录算法训练营之JAVA|第二十四天| 93. 复原 IP 地址

今天是第24天刷leetcode,立个flag,打卡60天。 算法挑战链接 93. 复原 IP 地址https://leetcode.cn/problems/restore-ip-addresses/ 第一想法 题目理解:将一串数字字符串变成正确的ip格式的字符串。 这类题目是切分字符串,ip一…...

网络安全 Day30-运维安全项目-堡垒机部署

运维安全项目-堡垒机部署 1. 运维安全项目-架构概述2. 运维安全项目之堡垒机2.1 堡垒机概述2.2 堡垒机选型2.3 环境准备2.4 部署Teleport堡垒机2.4.1 下载与部署2.4.2 启动2.4.3 浏览器访问teleport2.4.4 进行配置2.4.5 安装teleport客户端 2.5 teleport连接服务器 1. 运维安全…...

电脑文件夹备份命令

电脑文件夹备份 cmd窗口输入shell:startup 将备份.bat文件放到,自启动文件夹下 bat文件内容写以下就可以了 Xcopy "D:\文件\" "F:\文件备份\" /E/H/C/I/y...

RocketMQ Learning(一)

目录 一、RocketMQ 0、RocketMQ的产品发展 1、RocketMQ安装 1.1、windows下的安装 注意事项 1.2、Linux下的安装 1.3、源码的安装 1.4、控制台 2、消息发送方式 2.1、发送同步消息 2.2、发送异步消息 2.3、单向发送 3、消息消费方式 3.1、负载均衡模式&#xff0…...

libmpv使用滤镜处理视频进行播放

一、前言 作为一个功能强大的多媒体框架,libmpv为开发者提供了广泛的功能和灵活的控制权。滤镜是libmpv的一个重要特性,允许开发者对视频进行各种实时处理和增强,从而满足用户对于个性化、创意化和高质量视频体验的需求。 滤镜是一种在视频渲染过程中应用特定效果的技术。…...

怎么做相亲网站/seo公司怎么推广宣传

一、什么是表?但凡是用过MySQL都知道,直观上看,MySQL的数据都存在数据表中。比如一条Update SQL:update user set username 白日梦 where id 999;它将user这张数据表中id为1的记录的username列修改成了‘白日梦这里的user其实就…...

大连网站制作的/关键词搜索引擎

原来在家里的网络被偷了以后,电信的就一直没有来修理,说他们的修理费太高,决定把我们这里定为黑名单,也就是说在也不能通网络了,郁闷了。。。本来工作的地方离家就很远,骑电单车要120分钟,一天4…...

济南网站建设 泉诺/网站搭建详细教程

参考 C训练 (csdn.net) 目录 04HTTP 常用请求头 用户凭证Cookie Session 习题 06HTTPS 为什么使用HTTPS 2、SSL 3、TLS 4、证书与证书链 习题 07OSI七层模型 习题 08IP基础 1、IP分类 2、小知识 3、 网络类型 习题 09IPv6 10网络拓扑 习题 11域名解析 习…...

信息流广告视频/电脑优化是什么意思

本文用于自己记录,忘记时可以用来回顾。点击这里进入JQuerydatatable官网API地址 JQuery Datatables初始化 个人比较喜欢JQueryDatatables的Bootstrap4风格,所以文章以Bootstrap4风格为例。 JQueryDatatable的初始化很简单,按照官网的举例说明…...

制作企业网站软件/自媒体有哪些平台

文章目录labelme2voc其它数据集转换easydata2imageneteasydata2voceasydata2cocoeasydata2seglabelme2cocolabelme2segjingling2seglabelme2voc pdx.tools.labelme2voc(image_dir, json_dir, dataset_save_dir)将LabelMe标注的数据集转换为VOC数据集。 参数 image_dir (str)…...

杭州网站设计予尚/网站建设方案设计书

view-->word wrap; setting->preference-->vertical edge settings; Notepad中如何设置自动换行以及行宽 http://jingyan.baidu.com/article/6c67b1d68eddbc2787bb1e8c.html 转载于:https://www.cnblogs.com/mylinux/p/4741321.html...