- 初识React,基础(1), 安装react,jsx文件,类组件和函数组件,css样式
ybilss
reactreact.js前端前端框架
第一部分:初识reactreact:用于构建用户界面的JavaScript库全局安装,win+r,命令:npminstallcreate-react-app-g3.创建一个react应用,这里我在vscode里面创建,创建之后,运行create-react-appmy-appcdmy-appnpmstart第二部分:redact组件定义以及使用react中组件分为两种:类组件和函数组件,一般使用是
- 前端开发--node.js
前端_学习之路
nodejsnode.js
Node.js是一个基于ChromeV8引擎的JavaScript运行时环境,它使得JavaScript能够在服务器端运行,极大地扩展了JavaScript的应用范围。以下是关于Node.js的详细介绍:特点事件驱动:Node.js基于事件驱动架构,使用事件循环来处理并发操作。这意味着它可以高效地处理大量并发请求,而无需为每个请求创建新的线程,从而提高了性能和响应速度。非阻塞I/O:Node.js
- Vue05
memorycx
javascript
Vue05一个重要的内置关系:VueComponent.prototype.__proto____===Vue.prototyoe为什么要有这个关系:让组件实例对象(vc)可以访问到Vue原型上的属性和方法单文件组件注:cli的全称commandlineinterface一般叫做:脚手架具体步骤全局安装@vue/clinpminstall-g@vue/cli切换到你要创建项目的目录,然后使用命令创
- Vue 全局 Axios 封装:自动刷新 Token,解决登录过期难题
奶凶的小熊崽
前端vuejavascriptokhttpvueAxiosajax前端
在Vue项目中封装一个全局通用的AJAX请求函数,同时实现Token过期自动刷新,一般可以使用Axios进行封装,具体步骤如下:第一步:安装Axios如果项目中未安装axios,先安装它:npminstallaxios第二步:创建Axios实例在utils/request.js中封装请求实例:importaxiosfrom'axios';//创建Axios实例constservice=axios.
- Express + MongoDB 实现文件上传
yqcoder
expressmongodb数据库
使用`multer`中间件来处理文件上传,同时将文件的元数据存储到MongoDB中。一、安装依赖npminstallmulter二、核心代码//定义文件模型constfileSchema=newmongoose.Schema({ originalname:String, mimetype:String, size:Number, path:String,});constFile=mongoose.
- Readability.js 与 Newspaper提取网页内容和元数据
黑金IT
nodejs开发语言全文检索
在当今信息爆炸的时代,网页内容的提取和处理变得尤为重要。无论是从新闻网站、博客还是教程网站中提取内容,都需要一个高效、准确的工具来帮助我们去除无关信息,提取出有价值的正文内容。这不仅能够提高我们的工作效率,还能让我们更好地专注于内容本身。为什么选择Readability.js和Newspaper?Readability.js和Newspaper是两个非常流行的Node.js库,它们能够帮助我们从网
- Angular ng --help 源码分析
angular
先准备一下随便找个空文件夹,运行npmi@angular/
[email protected]使用npx--package=[@]--[args...]运行ng--helpC:\Users\zhouhuajian\Desktop\demo>npx--package=@angular/cli--ng--helpngCommands:ngbuild[project]CompilesanAngularapplicati
- Angular CLI 源码分析
准备:安装Node.jshttps://nodejs.org/;安装VSCodehttps://code.visualstudio.com/;创建文件夹angular-cli-source-learn;安装AngularCLInpminstall@angular/clihttps://www.npmjs.com/package/@angular/cli;开发时一般全局安装npminstall-g@
- 【综合项目】api系统——基于Node.js、express、mysql等技术
USER_A001
Node.jsnode.jsexpressmysqlapi
目录0前言1初始化2注册登录2.1注册2.1.1功能:密码加密(2.3.3)2.1.1.1操作2.1.1.2bcryptjs详解2.1.2插入新用户(2.3.4)2.1.3优化:表单数据验证(2.5)2.1.3.1过时代码修正2.1.3.2关键操作2.2登录2.2.1判断密码是否正确(2.6.3)2.2.2生成JWT的Token字符串的注意点(2.6.4)3个人中心3.1更新用户基本信息3.1.1
- Nodemailer使用教程:在Node.js中发送电子邮件
m0_74824054
面试学习路线阿里巴巴node.jslinux运维
目录1.简介2.安装3.基本配置3.1创建传输器3.2配置说明4.发送邮件4.1基本发送示例4.2发送验证码示例5.?常见问题解决5.1“Greetingneverreceived”?错误5.2?安全建议SMTP与邮件加密协议详解?1.SMTP简介1.1基本特点2.加密协议对比2.1SSL/TLS(端口465)?2.2?STARTTLS(端口587)3.端口使用建议3.1常用端口对比3.2选择建议
- 探索Node.js全栈开发新境界:Express后端API实践项目
黎玫洵Errol
探索Node.js全栈开发新境界:Express后端API实践项目todo-nodejs-apiNodeJS全栈开发之后端接口技术栈基于Node.js+Express+Mysql实现RESTFULAPI项目地址:https://gitcode.com/gh_mirrors/to/todo-nodejs-api在现代Web开发中,Node.js以其异步非阻塞I/O模型和高效的性能备受青睐。而当它邂逅
- 分布式监控Skywalking安装及使用教程(保姆级教程)(1)
2401_84181145
程序员分布式skywalking
前言本文主要讲解分布式链路追踪监控系统Skywalking的安装及使用教程,从0到1,图文并茂的保姆级教程。SkyWalking是一款用于分布式系统跟踪和性能监控的开源工具。它可以帮助开发人员了解分布式系统中不同组件之间的调用关系和性能指标,从而进行故障排查和性能优化。它支持多种语言和框架,包括Java、.NET、Node.js等。它通过在应用程序中插入代理或使用特定的SDK来收集跟踪数据,并将这
- web-view嵌套H5跳转小程序内部指定页面
猛男敲代码
前端小程序
第一步、安装微信JSSDK文件npminstalljweixin-module第二步、导入微信JSSDK文件importjWeixinfrom'jweixin-module';第三步、使用constjump=()=>{jWeixin.miniProgram.getEnv((res)=>{if(res.miniprogram){console.log('在小程序内部')jWeixin.miniPro
- Vue 3 项目中的路由管理详解
前端老曹
vue.js前端javascript
#随着前端单页应用(SPA)的兴起,路由管理成为了前端项目中不可或缺的一部分。VueRouter作为Vue.js官方的路由管理器,与Vue.js深度集成,为构建单页应用提供了强大的路由功能。在Vue3中,VueRouter也相应地进行了更新和优化,以更好地支持Vue3的新特性。本文将详细介绍Vue3项目中的路由管理。#一、VueRouter4概述VueRouter4是与Vue3配套使用的路由管理器
- ubuntu源码编译安装python3
骑台风走
ubuntulinux运维
#下载sudowgethttps://registry.npmmirror.com/-/binary/python/3.9.10/Python-3.9.10.tgz#解压sudotar-zxvfPython-3.9.10.tgz#进入cdPython-3.9.10.tgz##更新源+安装依赖sudoaptupdatesudoaptupgradesudoaptinstallbuild-essenti
- Vue Router 4与路由管理实战
qcidyu
文章归档动态路由代码分割路由懒加载导航守卫路由管理单页面应用VueRouter
title:VueRouter4与路由管理实战date:2024/6/7updated:2024/6/7excerpt:这篇文章介绍了如何在Vue.js应用中利用VueRouter实现单页面应用的路由管理,包括配置路由、导航守卫的使用、路由懒加载以优化性能以及动态路由的实现方法,旨在提升用户体验和应用加载效率categories:前端开发tags:VueRouter单页面应用路由管理导航守卫路由懒
- react+react-amap使用高德地图组件
浪天林
reactreactreact-amap地图
首先安装npminstall--savereact-amapreact-amap包含地图,覆盖物,信息窗体3类组件地图组件Map组件,Map的父组件必须具有宽度和高度;MouseTool组件,需要在地图上启用鼠标工具插件时使用;启用该插件可以进行鼠标画标记点、线、多边形、矩形、圆、距离量测、面积量测、拉框放大、拉框缩小等功能。constructor(){this.mapPlugins=['Tool
- (十一)基于vue3+mapbox-GL实现模拟高德实时导航轨迹播放
匹马夕阳
mapbox-gl集锦前端人工智能vuearcgis
要在Vue3项目中结合MapboxGL实现类似高德地图的实时导航轨迹功能,您可以按照以下步骤进行:安装依赖:首先,安装mapbox-gl和@turf/turf这两个必要的库:npminstallmapbox-gl@turf/turf引入MapboxGL:在组件中引入mapbox-gl并初始化地图实例:<script
- 基于Node.js和MongoDB 快速入门并实现一个RESTful API
AI天才研究院
Python实战自然语言处理人工智能语言模型编程实践开发语言架构设计
作者:禅与计算机程序设计艺术1.简介REST(RepresentationalStateTransfer)是一种基于HTTP协议的设计风格,它可以让客户端轻松地获取所需资源。RESTfulAPI(REpresentationalStateTransferApplicationProgrammingInterface)是一种API开发规范,它定义了如何从服务器端获取数据、创建、更新或删除资源。Nod
- 初识 Node.js
咖啡の猫
node.js后端
随着互联网技术的发展,前后端分离的架构模式越来越受到开发者们的青睐。而在众多后端解决方案中,Node.js以其独特的特性脱颖而出,成为构建高效、可扩展的网络应用的首选之一。本文将带你走进Node.js的世界,了解其基本概念、主要特点以及如何开始使用它来创建你的第一个Node.js应用。什么是Node.js?Node.js是一个基于ChromeV8引擎的JavaScript运行环境,允许开发者使用J
- vuejs 项目部署到nginx
爱分享的程序员
vue使用
一.vuejs项目配置文件根目录创建vue.config.js文件。如下:二.运行npmrunbuild指令将打包出来的dist文件拷贝到服务器的指定目录三.ngxin配置文件四.在服务器的根目录创建一个文件夹my-project,将dist里面的文件拷贝到创建的这个文件夹下面五.浏览器访问项目的路径http://localhost/my-project
- SpringBoot项目:前后端打包与部署(使用 Maven)
总是学不会.
mavenjava前端后端服务器
文章目录IDEA后端打包与部署(使用Maven)1.确保Maven已安装,并引入pom插件2.清理并安装项目3.定位生成的JAR包和配置文件4.创建部署文件夹5.上传到服务器前端打包与部署(使用npm)1.确保Node.js和npm已安装2.安装依赖3.构建生产环境代码4.准备部署文件夹5.上传到服务器自动化的想法可能出现的异常参考IDEA后端打包与部署(使用Maven)1.确保Maven已安装,
- 前端21:Vue.js开发实践指南
mater lai
本文还有配套的精品资源,点击获取简介:Vue.js是前端开发领域流行的JavaScript框架,"前端21"项目展示了基于Vue.js的Web应用程序开发。本文详细介绍了Vue.js的核心概念、项目设置、npm脚本、自定义配置、文件结构、开发过程和VueCLI工具,以帮助开发者高效构建Web应用。1.Vue.js框架基础1.1Vue.js简介Vue.js是一套构建用户界面的渐进式JavaScrip
- http 模块
咖啡の猫
node.js后端
在现代Web开发中,处理HTTP请求和响应是构建网络应用的核心部分。Node.js提供了一个强大的内置模块——http模块,使得开发者能够轻松创建服务器并处理客户端请求。本文将详细介绍http模块的基础知识、主要功能以及如何利用它来实现基本的Web服务器。什么是http模块?http模块是Node.js提供的一个核心模块,用于创建HTTP服务器与客户端。通过该模块,你可以编写服务器端代码来监听HT
- Vue 路由基础:Vue 2 和 Vue 3 的比较与使用
念九_ysl
Vuevue.js前端javascript
Vue.js是一款非常流行的前端框架,而VueRouter是Vue.js的官方路由管理库。在前端开发中,路由是处理页面跳转和视图管理的关键部分。Vue2和Vue3都使用VueRouter来管理路由,但是随着Vue3的发布,VueRouter也有了不少变化。在本文中,我们将详细介绍Vue2和Vue3中的路由使用,比较它们之间的不同,并提供一些示例代码。一、安装VueRouter在Vue项目中使用Vu
- Vue.js 全面技术指南
2301_81335708
vue.js前端javascript
目录1.Vue.js基础入门1.1脚手架安装1.2基础指令使用v-bind动态绑定v-model双向绑定1.3条件渲染2.核心概念详解2.1计算属性与监听器2.2Methods方法2.3Filters过滤器3.组件化开发3.1组件基础3.2组件通信4.实战应用4.1ElementUI使用4.2Axios网络请求4.3路由配置5.进阶技巧5.1BOM定时器5.2DOM操作总结Vue.js高级开发指南
- fluent-ffmpeg 依赖详解
yqcoder
ffmpeg
fluent-ffmpeg是一个用于在Node.js环境中与FFmpeg进行交互的强大库,它提供了流畅的API来执行各种音视频处理任务,如转码、剪辑、合并等。一、安装npminstallfluent-ffmpeg二、基本使用要使用fluent-ffmpeg,首先需要确保系统中已经安装了FFmpeg,或者使用ffmpeg-static等库提供静态的FFmpeg二进制文件。如下,展示如何将视频文件转换
- cookieParser 依赖详解
yqcoder
web安全前端
cookie-parser是一个用于在Express.js中解析HTTPCookie的Node.js中间件。它将Cookie字符串解析为JavaScript对象,使开发者能够方便地在Express应用中访问和操作Cookie。一、安装npminstallcookie-parser二、基本使用constexpress=require("express");constcookieParser=requ
- Express + MongoDB 实现 VOD 视频点播
yqcoder
expressmongodb数据库
一、安装依赖npminstallexpressmongoosemulterffmpeg-staticfluent-ffmpegexpress:用于构建Web服务器。mongoose:用于与MongoDB进行交互。multer:用于处理文件上传。ffmpeg-static:提供FFmpeg的静态二进制文件。fluent-ffmpeg:用于视频处理。二、数据库连接与模型定义创建models目录并在其中
- 在使用 npm link 进行本地 npm 包调试时,是否需要删除项目中已安装的依赖包取决于你的调试场景和依赖管理方式
Winson℡
nodenpm前端node.js
1.默认情况下不需要删除已安装的包npmlink的工作原理:当你在项目中运行npmlink时,npm会创建一个符号链接(symlink),将项目的node_modules/指向全局的软链包(通过npmlink在包目录生成)。这会覆盖node_modules中已存在的同名包,因此无需手动删除已安装的版本。示例流程:在包目录(要调试的包)中运行npmlink,将其注册到全局。在项目中运行npmlink
- Algorithm
香水浓
javaAlgorithm
冒泡排序
public static void sort(Integer[] param) {
for (int i = param.length - 1; i > 0; i--) {
for (int j = 0; j < i; j++) {
int current = param[j];
int next = param[j + 1];
- mongoDB 复杂查询表达式
开窍的石头
mongodb
1:count
Pg: db.user.find().count();
统计多少条数据
2:不等于$ne
Pg: db.user.find({_id:{$ne:3}},{name:1,sex:1,_id:0});
查询id不等于3的数据。
3:大于$gt $gte(大于等于)
&n
- Jboss Java heap space异常解决方法, jboss OutOfMemoryError : PermGen space
0624chenhong
jvmjboss
转自
http://blog.csdn.net/zou274/article/details/5552630
解决办法:
window->preferences->java->installed jres->edit jre
把default vm arguments 的参数设为-Xms64m -Xmx512m
----------------
- 文件上传 下载 解析 相对路径
不懂事的小屁孩
文件上传
有点坑吧,弄这么一个简单的东西弄了一天多,身边还有大神指导着,网上各种百度着。
下面总结一下遇到的问题:
文件上传,在页面上传的时候,不要想着去操作绝对路径,浏览器会对客户端的信息进行保护,避免用户信息收到攻击。
在上传图片,或者文件时,使用form表单来操作。
前台通过form表单传输一个流到后台,而不是ajax传递参数到后台,代码如下:
<form action=&
- 怎么实现qq空间批量点赞
换个号韩国红果果
qq
纯粹为了好玩!!
逻辑很简单
1 打开浏览器console;输入以下代码。
先上添加赞的代码
var tools={};
//添加所有赞
function init(){
document.body.scrollTop=10000;
setTimeout(function(){document.body.scrollTop=0;},2000);//加
- 判断是否为中文
灵静志远
中文
方法一:
public class Zhidao {
public static void main(String args[]) {
String s = "sdf灭礌 kjl d{';\fdsjlk是";
int n=0;
for(int i=0; i<s.length(); i++) {
n = (int)s.charAt(i);
if((
- 一个电话面试后总结
a-john
面试
今天,接了一个电话面试,对于还是初学者的我来说,紧张了半天。
面试的问题分了层次,对于一类问题,由简到难。自己觉得回答不好的地方作了一下总结:
在谈到集合类的时候,举几个常用的集合类,想都没想,直接说了list,map。
然后对list和map分别举几个类型:
list方面:ArrayList,LinkedList。在谈到他们的区别时,愣住了
- MSSQL中Escape转义的使用
aijuans
MSSQL
IF OBJECT_ID('tempdb..#ABC') is not null
drop table tempdb..#ABC
create table #ABC
(
PATHNAME NVARCHAR(50)
)
insert into #ABC
SELECT N'/ABCDEFGHI'
UNION ALL SELECT N'/ABCDGAFGASASSDFA'
UNION ALL
- 一个简单的存储过程
asialee
mysql存储过程构造数据批量插入
今天要批量的生成一批测试数据,其中中间有部分数据是变化的,本来想写个程序来生成的,后来想到存储过程就可以搞定,所以随手写了一个,记录在此:
DELIMITER $$
DROP PROCEDURE IF EXISTS inse
- annot convert from HomeFragment_1 to Fragment
百合不是茶
android导包错误
创建了几个类继承Fragment, 需要将创建的类存储在ArrayList<Fragment>中; 出现不能将new 出来的对象放到队列中,原因很简单;
创建类时引入包是:import android.app.Fragment;
创建队列和对象时使用的包是:import android.support.v4.ap
- Weblogic10两种修改端口的方法
bijian1013
weblogic端口号配置管理config.xml
一.进入控制台进行修改 1.进入控制台: http://127.0.0.1:7001/console 2.展开左边树菜单 域结构->环境->服务器-->点击AdminServer(管理) &
- mysql 操作指令
征客丶
mysql
一、连接mysql
进入 mysql 的安装目录;
$ bin/mysql -p [host IP 如果是登录本地的mysql 可以不写 -p 直接 -u] -u [userName] -p
输入密码,回车,接连;
二、权限操作[如果你很了解mysql数据库后,你可以直接去修改系统表,然后用 mysql> flush privileges; 指令让权限生效]
1、赋权
mys
- 【Hive一】Hive入门
bit1129
hive
Hive安装与配置
Hive的运行需要依赖于Hadoop,因此需要首先安装Hadoop2.5.2,并且Hive的启动前需要首先启动Hadoop。
Hive安装和配置的步骤
1. 从如下地址下载Hive0.14.0
http://mirror.bit.edu.cn/apache/hive/
2.解压hive,在系统变
- ajax 三种提交请求的方法
BlueSkator
Ajaxjqery
1、ajax 提交请求
$.ajax({
type:"post",
url : "${ctx}/front/Hotel/getAllHotelByAjax.do",
dataType : "json",
success : function(result) {
try {
for(v
- mongodb开发环境下的搭建入门
braveCS
运维
linux下安装mongodb
1)官网下载mongodb-linux-x86_64-rhel62-3.0.4.gz
2)linux 解压
gzip -d mongodb-linux-x86_64-rhel62-3.0.4.gz;
mv mongodb-linux-x86_64-rhel62-3.0.4 mongodb-linux-x86_64-rhel62-
- 编程之美-最短摘要的生成
bylijinnan
java数据结构算法编程之美
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
public class ShortestAbstract {
/**
* 编程之美 最短摘要的生成
* 扫描过程始终保持一个[pBegin,pEnd]的range,初始化确保[pBegin,pEnd]的ran
- json数据解析及typeof
chengxuyuancsdn
jstypeofjson解析
// json格式
var people='{"authors": [{"firstName": "AAA","lastName": "BBB"},'
+' {"firstName": "CCC&
- 流程系统设计的层次和目标
comsci
设计模式数据结构sql框架脚本
流程系统设计的层次和目标
 
- RMAN List和report 命令
daizj
oraclelistreportrman
LIST 命令
使用RMAN LIST 命令显示有关资料档案库中记录的备份集、代理副本和映像副本的
信息。使用此命令可列出:
• RMAN 资料档案库中状态不是AVAILABLE 的备份和副本
• 可用的且可以用于还原操作的数据文件备份和副本
• 备份集和副本,其中包含指定数据文件列表或指定表空间的备份
• 包含指定名称或范围的所有归档日志备份的备份集和副本
• 由标记、完成时间、可
- 二叉树:红黑树
dieslrae
二叉树
红黑树是一种自平衡的二叉树,它的查找,插入,删除操作时间复杂度皆为O(logN),不会出现普通二叉搜索树在最差情况时时间复杂度会变为O(N)的问题.
红黑树必须遵循红黑规则,规则如下
1、每个节点不是红就是黑。 2、根总是黑的 &
- C语言homework3,7个小题目的代码
dcj3sjt126com
c
1、打印100以内的所有奇数。
# include <stdio.h>
int main(void)
{
int i;
for (i=1; i<=100; i++)
{
if (i%2 != 0)
printf("%d ", i);
}
return 0;
}
2、从键盘上输入10个整数,
- 自定义按钮, 图片在上, 文字在下, 居中显示
dcj3sjt126com
自定义
#import <UIKit/UIKit.h>
@interface MyButton : UIButton
-(void)setFrame:(CGRect)frame ImageName:(NSString*)imageName Target:(id)target Action:(SEL)action Title:(NSString*)title Font:(CGFloa
- MySQL查询语句练习题,测试足够用了
flyvszhb
sqlmysql
http://blog.sina.com.cn/s/blog_767d65530101861c.html
1.创建student和score表
CREATE TABLE student (
id INT(10) NOT NULL UNIQUE PRIMARY KEY ,
name VARCHAR
- 转:MyBatis Generator 详解
happyqing
mybatis
MyBatis Generator 详解
http://blog.csdn.net/isea533/article/details/42102297
MyBatis Generator详解
http://git.oschina.net/free/Mybatis_Utils/blob/master/MybatisGeneator/MybatisGeneator.
- 让程序员少走弯路的14个忠告
jingjing0907
工作计划学习
无论是谁,在刚进入某个领域之时,有再大的雄心壮志也敌不过眼前的迷茫:不知道应该怎么做,不知道应该做什么。下面是一名软件开发人员所学到的经验,希望能对大家有所帮助
1.不要害怕在工作中学习。
只要有电脑,就可以通过电子阅读器阅读报纸和大多数书籍。如果你只是做好自己的本职工作以及分配的任务,那是学不到很多东西的。如果你盲目地要求更多的工作,也是不可能提升自己的。放
- nginx和NetScaler区别
流浪鱼
nginx
NetScaler是一个完整的包含操作系统和应用交付功能的产品,Nginx并不包含操作系统,在处理连接方面,需要依赖于操作系统,所以在并发连接数方面和防DoS攻击方面,Nginx不具备优势。
2.易用性方面差别也比较大。Nginx对管理员的水平要求比较高,参数比较多,不确定性给运营带来隐患。在NetScaler常见的配置如健康检查,HA等,在Nginx上的配置的实现相对复杂。
3.策略灵活度方
- 第11章 动画效果(下)
onestopweb
动画
index.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/
- FAQ - SAP BW BO roadmap
blueoxygen
BOBW
http://www.sdn.sap.com/irj/boc/business-objects-for-sap-faq
Besides, I care that how to integrate tightly.
By the way, for BW consultants, please just focus on Query Designer which i
- 关于java堆内存溢出的几种情况
tomcat_oracle
javajvmjdkthread
【情况一】:
java.lang.OutOfMemoryError: Java heap space:这种是java堆内存不够,一个原因是真不够,另一个原因是程序中有死循环; 如果是java堆内存不够的话,可以通过调整JVM下面的配置来解决: <jvm-arg>-Xms3062m</jvm-arg> <jvm-arg>-Xmx
- Manifest.permission_group权限组
阿尔萨斯
Permission
结构
继承关系
public static final class Manifest.permission_group extends Object
java.lang.Object
android. Manifest.permission_group 常量
ACCOUNTS 直接通过统计管理器访问管理的统计
COST_MONEY可以用来让用户花钱但不需要通过与他们直接牵涉的权限
D