Python-S9——Day82-CRM项目实战
1、权限的概念;
2、RBAC的设计;
3、注册登录用户所有权限到session中;
4、权限的校验;
5、基于中间件的权限校验;
1、权限的概念;
1.1 项目与应用;
- Project
- App
1.2 什么是权限?一个URL就是一个权限;
1.2.1 who what how <------>True or False
1.2.2 表相关,如UserInfo、Permission、UserInfo_Permission;
1.2.3 管理员权限,比如腾旭视频的VIP会员,这个世界上权限无处不在;
1.2.4 应用范围最广泛;
1.2.5 Who、What、How------>True Or Flase
2、RBAC的设计;
2.1 不同的角色设置不同的权限;
2.2 新增一张Role(角色表);
- UserInfo
- Role
- Permission
2.3 rbac(Role base access control)
3、注册登录用户所有权限到session中;
3.1 基于rbac/models.py生成关系表;
from django.db import models # Create your models here. class User(models.Model):
name = models.CharField(max_length=32)
pwd = models.CharField(max_length=32)
roles = models.ManyToManyField(to="Role") def __str__(self):
return self.name class Role(models.Model):
title = models.CharField(max_length=32)
permissions = models.ManyToManyField(to="Permission") def __str__(self):
return self.title class Permission(models.Model):
title = models.CharField(max_length=32)
url = models.CharField(max_length=32) def __str__(self):
return self.title
2、进行数据库迁移操作;
python manage.py makemigrations
python migrate
3、在rbac/admin.py中进行register注册操作;
from django.contrib import admin # Register your models here.
from .models import * admin.site.register(User)
admin.site.register(Role)
admin.site.register(Permission)
4、进行超级用户的创建cuixiaozhao;
Microsoft Windows [版本 10.0.17134.1]
(c) 2018 Microsoft Corporation。保留所有权利。 (venv) C:\Users\TQTL911\PycharmProjects\s9day82_rbac>python manage.py startapp rbac (venv) C:\Users\TQTL911\PycharmProjects\s9day82_rbac>python manage.py makemigrations
Traceback (most recent call last):
File "manage.py", line 15, in <module>
execute_from_command_line(sys.argv)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\management\__init__.py", line 381, in execute_from_command_line
utility.execute()
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\management\__init__.py", line 375, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\management\base.py", line 316, in run_from_argv
self.execute(*args, **cmd_options)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\management\base.py", line 350, in execute
self.check()
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\management\base.py", line 379, in check
include_deployment_checks=include_deployment_checks,
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\management\base.py", line 366, in _run_checks
return checks.run_checks(**kwargs)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\checks\registry.py", line 71, in run_checks
new_errors = check(app_configs=app_configs)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\checks\urls.py", line 40, in check_url_namespaces_unique
all_namespaces = _load_all_namespaces(resolver)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\core\checks\urls.py", line 57, in _load_all_namespaces
url_patterns = getattr(resolver, 'url_patterns', [])
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\utils\functional.py", line 37, in __get__
res = instance.__dict__[self.name] = self.func(instance)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\urls\resolvers.py", line 533, in url_patterns
patterns = getattr(self.urlconf_module, "urlpatterns", self.urlconf_module)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\utils\functional.py", line 37, in __get__
res = instance.__dict__[self.name] = self.func(instance)
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\venv\lib\site-packages\django\urls\resolvers.py", line 526, in urlconf_module
return import_module(self.urlconf_name)
File "C:\Program Files\Python36\lib\importlib\__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 994, in _gcd_import
File "<frozen importlib._bootstrap>", line 971, in _find_and_load
File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 678, in exec_module
File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\s9day82_rbac\urls.py", line 18, in <module>
from app01 import views
File "C:\Users\TQTL911\PycharmProjects\s9day82_rbac\app01\views.py", line 5
user_id = request.
^
SyntaxError: invalid syntax (venv) C:\Users\TQTL911\PycharmProjects\s9day82_rbac>python manage.py makemigrations
Migrations for 'app01':
app01\migrations\0001_initial.py
- Create model User
Migrations for 'rbac':
rbac\migrations\0001_initial.py
- Create model Permission
- Create model Role
- Create model User (venv) C:\Users\TQTL911\PycharmProjects\s9day82_rbac>python manage.py migrate
Operations to perform:
Apply all migrations: admin, app01, auth, contenttypes, rbac, sessions
Running migrations:
Applying contenttypes.0001_initial... OK
Applying auth.0001_initial... OK
Applying admin.0001_initial... OK
Applying admin.0002_logentry_remove_auto_add... OK
Applying admin.0003_logentry_add_action_flag_choices... OK
Applying app01.0001_initial... OK
Applying contenttypes.0002_remove_content_type_name... OK
Applying auth.0002_alter_permission_name_max_length... OK
Applying auth.0003_alter_user_email_max_length... OK
Applying auth.0004_alter_user_username_opts... OK
Applying auth.0005_alter_user_last_login_null... OK
Applying auth.0006_require_contenttypes_0002... OK
Applying auth.0007_alter_validators_add_error_messages... OK
Applying auth.0008_alter_user_username_max_length... OK
Applying auth.0009_alter_user_last_name_max_length... OK
Applying rbac.0001_initial... OK
Applying sessions.0001_initial... OK (venv) C:\Users\TQTL911\PycharmProjects\s9day82_rbac>python manage.py createsuperuser
Username (leave blank to use 'tqtl911'): cuixiaozhao
Email address: tqtl@tqtl.org
Password:
Password (again):
This password is too common.
Bypass password validation and create user anyway? [y/N]: y
Superuser created successfully. (venv) C:\Users\TQTL911\PycharmProjects\s9day82_rbac>
5、启动Django项目,进行admin后台访问;
6、分别通过前端页面,进行Permission、Role、User的添加操作;
7、在settings.py中添加INSTALLED_APPS并配置urls.py;
"""s9day82_rbac URL Configuration The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/2.1/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from app01 import views urlpatterns = [
path('admin/', admin.site.urls),
path('users/', views.users),
path('^/users/add', views.add_user),
path('^roles/', views.roles),
path('login/', views.login),
]
8、编写视图函数views.py;
from django.shortcuts import render, HttpResponse # Create your views here. from rbac.models import * def users(request):
user_list = User.objects.all()
return render(request, "users.html", locals()) def add_user(request):
return HttpResponse("add_user") def roles(request):
user_list = User.objects.all()
return render(request, "users.html", locals()) def login(request):
if request.method == "POST":
user = request.POST.get("user")
pwd = request.POST.get("pwd")
user_obj = User.objects.filter(name=user, pwd=pwd).first()
if user_obj:
# 在session中注册用户的ID;
request.session["user_id"] = user.pk '''
在session中注册权限列表;
'''
# #查询当前登录用的所有角色;
# ret = user_obj.roles.all()
# print(ret)#<QuerySet [<Role: 保洁>, <Role: 销售>]>
# 查询当前登录用的所有权限; # ret = user_obj.roles.all().values("title")
# ret = user_obj.roles.all().values("title",
# "permissions__url") # <QuerySet [{'title': '保洁', 'permissions__url': '/users/'}, {'title': '销售', 'permissions__url': '/users/'}, {'title': '销售', 'permissions__url': '/users/add'}]> permissions = user_obj.roles.all().values(
"permissions__url").distinct() # <QuerySet [{'permissions__url': '/users/'}, {'permissions__url': '/users/add'}]>
permission_list = [] # 定义一个空列表;
for item in permissions:
permission_list.append(item["permissions__url"])
print(permission_list) # ['/users/', '/users/add']
request.session["permission_list"] = permission_list
'''
values:
temp = []
for role in user.roles.all(): #[<Role:保洁>,<Role:销售>]
temp.append({
"title":role.title,#<QuerySet [{'title': '保洁'}, {'title': '销售'}]>
})
'''
return HttpResponse("登录成功!") return render(request, "login.html")
9、编写templates下的login.html;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style type="text/css"> </style>
</head>
<body>
<h4>登录页面</h4>
<form action="" method="post">
{% csrf_token %}
用户名: <input type="text" name="user"></input>
密码: <input type="password" name="pwd"></input>
<input type="submit">
</form>
</body>
</html>
users.html;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style type="text/css"> </style>
</head>
<body>
<ul>
<h4>用户列表</h4>
{% for user in user_list %}
<p>{{ user }}</p>
{% endfor %} </ul>
</body>
</html>
4、权限的校验;
1、一个含有正则表达式的URL就是一个权限;
2、permission = “^%s$”%permission;
urls.py;
"""s9day82_rbac URL Configuration The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/2.1/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from app01 import views urlpatterns = [
path('admin/', admin.site.urls),
path('users/', views.users),
path('users/add', views.add_user),
path('roles/', views.roles),
path('login/', views.login),
]
views.py;
from django.shortcuts import render, HttpResponse # Create your views here. from rbac.models import * def users(request):
user_list = User.objects.all()
return render(request, "users.html", locals()) def add_user(request):
permission_list = request.session[
"permission_list"] # ['/users/', '/users/add', '/users/delete/(\\d+)', 'users/edit(\\d+)']
current_path = request.path_info
if current_path in permission_list:
pass return HttpResponse("add_user") def roles(request):
user_list = User.objects.all()
return render(request, "users.html", locals()) def login(request):
if request.method == "POST":
user = request.POST.get("user")
pwd = request.POST.get("pwd")
user_obj = User.objects.filter(name=user, pwd=pwd).first()
if user_obj:
# 在session中注册用户的ID;
request.session["user_id"] = user_obj.pk '''
在session中注册权限列表;
'''
# #查询当前登录用的所有角色;
# ret = user_obj.roles.all()
# print(ret)#<QuerySet [<Role: 保洁>, <Role: 销售>]>
# 查询当前登录用的所有权限; # ret = user_obj.roles.all().values("title")
# ret = user_obj.roles.all().values("title",
# "permissions__url") # <QuerySet [{'title': '保洁', 'permissions__url': '/users/'}, {'title': '销售', 'permissions__url': '/users/'}, {'title': '销售', 'permissions__url': '/users/add'}]> permissions = user_obj.roles.all().values(
"permissions__url").distinct() # <QuerySet [{'permissions__url': '/users/'}, {'permissions__url': '/users/add'}]>
permission_list = [] # 定义一个空列表;
for item in permissions:
permission_list.append(item["permissions__url"])
print(permission_list) # ['/users/', '/users/add']
request.session["permission_list"] = permission_list
'''
values:
temp = []
for role in user.roles.all(): #[<Role:保洁>,<Role:销售>]
temp.append({
"title":role.title,#<QuerySet [{'title': '保洁'}, {'title': '销售'}]>
})
'''
return HttpResponse("登录成功!") return render(request, "login.html")
test.py;
from django.test import TestCase # Create your tests here. l = ['/users/', '/users/add', '/users/delete/(\\d+)', 'users/edit(\\d+)']
c_path = "users/delete/9" import re flag = False
for permission in l:
permission = "^%s$"%permission
ret = re.match("", c_path)
if ret:
flag = True
break
if flag:
print("Success!")
5、基于中间件的权限校验;
1、创建表关系:
2、基于admin录入数据;
3、 登录校验:
4、校验权限(中间件的应用)
5、自定义中间件,并在settings.py中配置;
6、配置白名单valid_url_list;
settings.py;
"""
Django settings for s9day82_rbac project. Generated by 'django-admin startproject' using Django 2.1. For more information on this file, see
https://docs.djangoproject.com/en/2.1/topics/settings/ For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.1/ref/settings/
""" import os # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'lp7xgai1mm6&w^!2jj3gj6j*fd)0^%nzks)w4t$a89s@c&zwt_' # SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True ALLOWED_HOSTS = [] # Application definition INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01.apps.App01Config',
'rbac.apps.RbacConfig',
] 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',
'rbac.service.rbac.ValidPermission',
] ROOT_URLCONF = 's9day82_rbac.urls' TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')]
,
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
] WSGI_APPLICATION = 's9day82_rbac.wsgi.application' # Database
# https://docs.djangoproject.com/en/2.1/ref/settings/#databases DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
} # Password validation
# https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators AUTH_PASSWORD_VALIDATORS = [
{
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
},
] # Internationalization
# https://docs.djangoproject.com/en/2.1/topics/i18n/ LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_L10N = True USE_TZ = True # Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.1/howto/static-files/ STATIC_URL = '/static/'
models.py;
from django.db import models # Create your models here. class User(models.Model):
name = models.CharField(max_length=32)
pwd = models.CharField(max_length=32)
roles = models.ManyToManyField(to="Role") def __str__(self):
return self.name class Role(models.Model):
title = models.CharField(max_length=32)
permissions = models.ManyToManyField(to="Permission") def __str__(self):
return self.title class Permission(models.Model):
title = models.CharField(max_length=32)
url = models.CharField(max_length=32) def __str__(self):
return self.title
urls.py;
"""s9day82_rbac URL Configuration The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/2.1/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from app01 import views urlpatterns = [
path('admin/', admin.site.urls),
path('users/', views.users),
path('users/add', views.add_user),
path('roles/', views.roles),
path('login/', views.login),
]
views.py;
from django.shortcuts import render, HttpResponse # Create your views here. from rbac.models import *
from rbac.service.permissions import *
import re def users(request):
user_list = User.objects.all()
return render(request, "users.html", locals()) def add_user(request): return HttpResponse("add_user") def roles(request):
#写个中间件; role_list = Role.objects.all()
return render(request, "roles.html", locals()) def login(request):
if request.method == "POST":
user = request.POST.get("user")
pwd = request.POST.get("pwd")
user_obj = User.objects.filter(name=user, pwd=pwd).first()
if user_obj:
# 在session中注册用户的ID;
request.session["user_id"] = user_obj.pk '''
在session中注册权限列表;
'''
# #查询当前登录用的所有角色;
# ret = user_obj.roles.all()
# print(ret)#<QuerySet [<Role: 保洁>, <Role: 销售>]>
# 查询当前登录用的所有权限; # ret = user_obj.roles.all().values("title")
# ret = user_obj.roles.all().values("title",
# "permissions__url") # <QuerySet [{'title': '保洁', 'permissions__url': '/users/'}, {'title': '销售', 'permissions__url': '/users/'}, {'title': '销售', 'permissions__url': '/users/add'}]> #查询当前登录用户的所有权限;
initial_session(user_obj,request)
'''
values:
temp = []
for role in user.roles.all(): #[<Role:保洁>,<Role:销售>]
temp.append({
"title":role.title,#<QuerySet [{'title': '保洁'}, {'title': '销售'}]>
})
'''
return HttpResponse("登录成功!") return render(request, "login.html")
permissions.py;
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
# __Author__:TQTL911
# Version:python3.6.6
# Time:2018/8/29 22:28 def initial_session(user_obj,request):
permissions = user_obj.roles.all().values(
"permissions__url").distinct() # <QuerySet [{'permissions__url': '/users/'}, {'permissions__url': '/users/add'}]>
permission_list = [] # 定义一个空列表;
for item in permissions:
permission_list.append(item["permissions__url"])
print(permission_list) # ['/users/', '/users/add']
request.session["permission_list"] = permission_list
rbac.py;
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
# __Author__:TQTL911
# Version:python3.6.6
# Time:2018/8/29 22:03
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse, redirect
import re class ValidPermission(MiddlewareMixin):
def process_request(self, request):
# 当前访问的路径;
current_path = request.path_info
# 校验权限,检查是否属于白名单;
varlid_url_list = ["/login/", "/reg/", "/admin/.*"]
for valid_url in varlid_url_list:
ret = re.match(valid_url, current_path)
if ret:
return None
# 校验是否登录;
user_id = request.session.get("user_id")
if not user_id:
return redirect("/login/") if current_path in varlid_url_list:
return None # 权限的校验;
permission_list = request.session.get("permission_list",
[]) # ['/users/', '/users/add', '/users/delete/(\\d+)', 'users/edit(\\d+)']
flag = False
for permission in permission_list:
permission = "^%s$" % permission
ret = re.match(permission, current_path)
if ret:
flag = True
break
if not flag:
return HttpResponse("没有访问权限")
return None
tests.py;
from django.test import TestCase # Create your tests here. l = ['/users/', '/users/add', '/users/delete/(\\d+)', 'users/edit(\\d+)']
c_path = "users/delete/9" import re flag = False
for permission in l:
permission = "^%s$"%permission
ret = re.match("", c_path)
if ret:
flag = True
break
if flag:
print("Success!")
users.html;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style type="text/css"> </style>
</head>
<body>
<ul>
<h4>用户列表</h4>
{% for user in user_list %}
<p>{{ user }}</p>
{% endfor %} </ul>
</body>
</html>
roles.html;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>roles</title>
<style type="text/css"> </style>
</head>
<body>
<ul>
<h4>角色列表</h4>
{% for role in role_list %}
<p>{{ role }}</p>
{% endfor %} </ul>
</body>
</html>
5 权限按钮控制的简单形式;
5.1
6 权限菜单显示
7 Django的路径自动添加问题
7.1 settings.py中添加APPEND_SLASH = FALSE,默认为True,解决URL末尾路径斜杠自动添加的问题;
8 原生form实现增删改查
9 modelform实现增删改查
Python-S9——Day82-CRM项目实战的更多相关文章
- Python爬虫开发与项目实战
Python爬虫开发与项目实战(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1MFexF6S4No_FtC5U2GCKqQ 提取码:gtz1 复制这段内容后打开百度 ...
- Python爬虫开发与项目实战pdf电子书|网盘链接带提取码直接提取|
Python爬虫开发与项目实战从基本的爬虫原理开始讲解,通过介绍Pthyon编程语言与HTML基础知识引领读者入门,之后根据当前风起云涌的云计算.大数据热潮,重点讲述了云计算的相关内容及其在爬虫中的应 ...
- python工业互联网监控项目实战5—Collector到opcua服务
本小节演示项目是如何从连接器到获取Tank4C9服务上的设备对象的值,并通过Connector服务的url返回给UI端请求的.另外,实际项目中考虑websocket中间可能因为网络通信等原因出现中断情 ...
- python工业互联网监控项目实战4—python opcua
前面章节我们采用OPC作为设备到上位的信息交互的协议,本章我们介绍跨平台的OPC UA.OPC作为早期的工业通信规范,是基于COM/DCOM的技术实现的,用于设备和软件之间交换数据,最初,OPC标准仅 ...
- python金融反欺诈-项目实战
python信用评分卡(附代码,博主录制) https://study.163.com/course/introduction.htm?courseId=1005214003&utm_camp ...
- python工业互联网监控项目实战2—OPC
OPC(OLE for Process Control)定义:指为了给工业控制系统应用程序之间的通信建立一个接口标准,在工业控制设备与控制软件之间建立统一的数据存取规范.它给工业控制领域提供了一种标准 ...
- python数据分析美国大选项目实战(三)
项目介绍 项目地址:https://www.kaggle.com/fivethirtyeight/2016-election-polls 包含了2015年11月至2016年11月期间对于2016美国大 ...
- Python工业互联网监控项目实战3—websocket to UI
本小节继续演示如何在Django项目中采用早期websocket技术原型来实现把OPC服务端数据实时推送到UI端,让监控页面在另一种技术方式下,实时显示现场设备的工艺数据变化情况.本例我们仍然采用比较 ...
- Python轻松入门到项目实战-实用教程
本课程完全基于Python3讲解,针对广大的Python爱好者与同学录制.通过本课程的学习,可以让同学们在学习Python的过程中少走弯路.整个课程以实例教学为核心,通过对大量丰富的经典实例的讲解.让 ...
- 机器学习_线性回归和逻辑回归_案例实战:Python实现逻辑回归与梯度下降策略_项目实战:使用逻辑回归判断信用卡欺诈检测
线性回归: 注:为偏置项,这一项的x的值假设为[1,1,1,1,1....] 注:为使似然函数越大,则需要最小二乘法函数越小越好 线性回归中为什么选用平方和作为误差函数?假设模型结果与测量值 误差满足 ...
随机推荐
- github commit 报错:error: failed to push some refs to 'https:'错误解决方法
为什么会出现这个问题呢? 因为我在github中删除了一个文件readme.txt,但是本地并不知道我删除了readme.txt,本地中还保存了readme.txt文件,导致了云端的文件,和本地的文件 ...
- 阿里前端测试题--关于ES6中Promise函数的理解与应用
今天做了阿里前端的笔试题目,原题目是这样的 //实现mergePromise函数,把传进去的数组顺序先后执行,//并且把返回的数据先后放到数组data中 const timeout = ms => ...
- 如果有人问你CAP理论是什么,就把这篇文章发给他。
绝对和你在网上看到的CAP定理介绍不一样. CAP 定理(CAP theorem)又被称作布鲁尔定理(Brewer's theorem),是加州大学伯克利分校的计算机科学家埃里克·布鲁尔(Eric B ...
- Swift_闭包
Swift_闭包 点击查看源码 闭包优化 //闭包优化 func testClosures() { //函数做参数 排序 let names = ["XuBaoAiChiYu", ...
- Spring知识点小结汇总
Spring部分 1.谈谈你对spring IOC和DI的理解,它们有什么区别? IoC Inverse of Control 反转控制的概念,就是将原本在程序中手动创建UserService对象的控 ...
- mount/umount命令
挂载及卸载指定的文件系统 mount [选项] [-L<标签>] [-o<选项>] [-t<文件系统类型>] [设备名] [挂载点] umount [挂载点] -a ...
- Shell中的${}、##和%%使用范例
假设定义了一个变量为,代码如下: file=/dir1/dir2/dir3/my.file.txt 可以用${ }分别替换得到不同的值: ${file#*/}: 删掉第一个 / 及其左边的字符串:di ...
- HTML-CSS的几种布局
第一种 两栏式布局 <body> <!-- 两栏式布局 --> <!-- 想要的效果是左边图片右边文字 拉伸盒子文字的高度宽度自动改变 --> <div c ...
- Flask之Flask实例有哪些参数
常用的参数应用实例 from flask import Flask, render_template, url_for, session, request, redirect app = Flask( ...
- thinkphp5 部署到iis服务器url重写
thinkphp部署到iis服务器配置url重写的解决方法: 1.下载 url rewrite.下载地址:https://www.iis.net/downloads/microsoft/url-rew ...