本文转自LaplaceDemon/SJQ的博客园【http://www.cnblogs.com/shijiaqi1066/p/3821150.html


本文使用node.js v0.10.28 + express 4.2.0

 

1 Express概述

Express 是一个简洁而灵活的node.js的MVC Web应用框架,提供一系列强大特性创建各种Web应用。

Express 不对 node.js 已有的特性进行二次抽象,我们只是在它之上扩展了Web应用所需的功能。

Expressd底层由Node.js的HTTP模块实现。

 

 

1.1 express 4.x 安装

express 4.x与之前的版本有了许多的变化,书里和网上的很多方法都不再适用。学习需要更多的参考官方文档。

若需要用express 3.x版本,直接使用nmp 中的@字符确定版本,指令如下:

npm install -g express-generator@3

若需要使用4.x,注意的问题在4.x版本express 已经把命令行工具分离出来。

现在全局安装只需要安装这个命令行工具就可以,指令如下:

npm install -g express-generator

wps_clip_image-23406

 

 

 

1.2 创建express工程

使用express命令

express [options]

选项:

  -h, --help         输出使用信息

  -V, --version      输出版本号

  -e, --ejs          添加ejs的支持(默认使用jade)

  -H, --hogan       添加hogan.js引擎的支持

  -c, --css          添加css(less 或stylus 或compass)的支持

  -f, --force         强迫接受非空目录

wps_clip_image-23155

 

 

1.2.1 创建hello-express的工程

使用命令:express hello-express ,默认创建基于jade的项目。

wps_clip_image-32696

 

 

使用-e参数创建基于ejs的项目。使用命令:express -e hello-express

wps_clip_image-14881

 

 

在当前目录下会创建新的目录。

wps_clip_image-6317

 

目录内容如下所示:

wps_clip_image-28261

 

进入到工程目录

wps_clip_image-2331

 

 

1.2.2 安装express及依赖

使用命令:npm install

wps_clip_image-21901

 

该过程会自动下载网络上的依赖包,请耐心等待命令结束。创建包后,可查看目下的package.json文件:

wps_clip_image-2537

 

 

1.2.3 启动工程

使用命令:npm start

wps_clip_image-4466

注意:该实例无法以 node app.js 为启动方式,而是用指令 npm start 作为启动。原因如下所述。

 

npm执行的时候会读取当前目录的package.json文件,这个也就是我上面那个bug出现的原因

执行npm start其实是执行package.json中的script对应的对象中的start属性所对应的命令行。

wps_clip_image-30700

 

 

也就是执行bin/www文件,该文件无后缀名。使用文本工具打开,可以看到其中的脚本。npm start命令,就是执行的该脚本程序。

wps_clip_image-19564

 

 

express默认端口为3000。浏览器访问 http://127.0.0.1:3000/ 。显示页面Welcome to Express,即安装成功。

wps_clip_image-31123

 

 

 

1.3 目录解释

如果浏览这个子目录,就会发现express自动生成了以下的子目录和文件。

  • node_modules子目录:用于安装本地模块。
  • public子目录:用于存放用户可以下载到的文件,比如图片、脚本、样式表等。
  • routes子目录:用于存放路由文件。
  • views子目录:用于存放网页的模板。
  • app.js文件:应用程序的启动脚本。
  • package.json文件:项目的配置文件。

当对express工程目录和package.json文件熟悉后,可以手动创建工程,而不用依赖express命令。

 

 

1.4 解析express命令生成工程的代码

bin/www

复制代码
#!/usr/bin/env nodevar debug = require('debug')('hello-express');
var app = require('../app');    //引入app模块app.set('port', process.env.PORT || 3000);     //设置’port’var server = app.listen(app.get('port'), function() {     //获取’port’,并监听。debug('Express server listening on port ' + server.address().port);});
复制代码

 

 

app.js

复制代码
var express = require('express');    //引入express
var path = require('path');         //引入path
var favicon = require('static-favicon');    //引入static-favicon
var logger = require('morgan');    //引入morgan
var cookieParser = require('cookie-parser');    //引入cookie-parser
var bodyParser = require('body-parser');    //引入body-parservar routes = require('./routes/index');    //引入路由index
var users = require('./routes/users');    //引入路由usersvar app = express();             //创建一个app// 设置视图引擎。
app.set('views', path.join(__dirname, 'views'));    //设置视图文件所在位置。
app.set('view engine', 'ejs');                    //设置视图引擎。app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());app.use(express.static(path.join(__dirname, 'public')));    //指定静态文件所在位置/*请求时,服务器端就到public目录寻找这个文件。比如,浏览器发出如下的样式表请求:<link href="/bootstrap/css/bootstrap.css" rel="stylesheet">服务器端就到public/bootstrap/css/目录中寻找bootstrap.css文件。*/app.use('/', routes);    //对’/’设置路由。
app.use('/users', users);    //对’/user’设置路由。//捕获404并对跳转错误进行处理。
app.use(function(req, res, next) {var err = new Error('Not Found');err.status = 404;next(err);
});// 开发环境错误处理。
if (app.get('env') === 'development') {app.use(function(err, req, res, next) {res.status(err.status || 500);res.render('error', {        //渲染error.ejs。message: err.message,error: err});});
}// 生产环境错误处理。
// 没有堆栈跟踪泄露给用户。
app.use(function(err, req, res, next) {res.status(err.status || 500);res.render('error', {message: err.message,error: {}});
});module.exports = app;   //将app设为模块。
复制代码

 

 

views/index.ejs

复制代码
<!DOCTYPE html>
<html><head><title><%= title %></title><link rel='stylesheet' href='/stylesheets/style.css' /> <!--由于已经设置了静态文件位置,服务器会自动在public目录中寻找。--></head><body><h1><%= title %></h1><p>Welcome to <%= title %></p></body>
</html>
复制代码

 

 

views/error.ejs

<h1><%= message %></h1>
<h2><%= error.status %></h2>
<pre><%= error.stack %></pre>

 

 

routes/index.js

复制代码
var express = require('express');
var router = express.Router();    //获取路由对象。/* GET home page. */
router.get('/', function(req, res) {res.render('index', { title: 'Express' });    //页面渲染index.ejs。
});module.exports = router;    //设置为模块。
复制代码

 

 

routes/users.js

复制代码
var express = require('express');
var router = express.Router();    //获取路由对象。/* GET users listing. */
router.get('/', function(req, res) {res.send('respond with a resource');    //respones直接返回字符串。
});module.exports = router;    //将本路由设置为模块。
复制代码

 

 

 

 

2 Express基本组件

2.1 Express的中间件

Express中的中间件(middleware)类似于JavaEE中拦截器的概念。

Express中的中间件由函数表示:

function uselessMiddleware(req, res, next) {next();
}

 

 

每个中间件都可以对HTTP请求(request对象)做出回应。调用next方法会将request对象再传给下一个中间件。next方法如果带有参数,则代表抛出一个错误,参数为错误文本。

function uselessMiddleware(req, res, next) {next('出错了!');
}

 

 

 

2.2 user()方法

user方法用于将路径与中间件函数或路由对象绑定起来。默认路径为”/”。

app.use([path], function)

复制代码
var express = require('express');var app = express();// simple logger
app.use(function(req, res, next){console.log('%s %s', req.method, req.url);next();
});// respond
app.use(function(req, res, next){res.send('Hello World');
});app.listen(3000);
复制代码

 

 

 

2.3 静态资源

静态资源的获取是use()函数的典型应用。express.static()方法为静态资源指定目录。use()方法用于绑定拦截http请求,若请求的静态资源存在,则返回静态资源文件。

例:js、css、图片分别位于工程路径的public目录中。

// GET /static/javascripts/jquery.js
// GET /static/style.css
// GET /static/favicon.ico
app.use(express.static(__dirname + '/public'));

注意:

对不同url使用use()函数,各use()函数顺序,先拦截到http请求的中间件函数会先被执行。而且,use()方法与路由方法的顺序也需要注意。

一般的,use()方法位于路由方法之前。

 

例:当请求"GET /javascripts/jquery.js" 时,会先检查 "./public/javascripts/jquery.js",若不存在,随后的中间件会检查 "./files/javascripts/jquery.js"。

app.use(express.static('public'));
app.use(express.static('files'));

 

 

 

2.4 异常处理

定义错误处理的中间件跟定义普通的中间件没有什么区别,仅仅是参数必须定义为4个,定义如下 (err, req, res, next)

app.use(function(err, req, res, next){console.error(err.stack);res.send(500, 'Something broke!');
});

 

 

 

2.5 请求路由

2.5.1 路由方法

app.VERB(url, callback(req, res))

app.VERB(url, callback1(req, res),callback2(req, res),......,callbackn(req, res))

app.VERB() 方法为Express提供路由方法,VERB 是指某一个HTTP 动作,比如,app.post()。

app.VERB() 方法可以提供多个callbacks,多个callbacks会被平等对待,它们的行为跟中间件类似,不同的是,若某一个callback执行了next('route'),此后的callback就被忽略。这种情形会应用在当满足一个路由前缀,但是不需要处理这个路由,于是把它向后传递。

 

 

2.5.2 Router 路由

Express 4.x使用Router组件对URL进行响应处理。在Express 4.x 应该尽量多使用 express.Router 来代替app.VERB方式的路由。

express.Router使得整个控制器变成了一个不依赖于任何外部实例的独立模块,更有利于模块的拆分,同时对于测试也更加友好。

express.Router可以认为是一个微型的只用来处理中间件与控制器的app,它拥有和 app 类似的方法,例如 get、post、all、use 等等。

 

app.js

app.use(require('./controllers/book'));

 

 

controllers/book.js

复制代码
var router = require('express').Rouer(); // 新建一个 routervar A = require('../middlewares/A');
var B = require('../middlewares/B');
var C = require('../middlewares/C');// 在 router 上装备控制器与中间件
router.get('/books', A, B, C, function (req, res) {var retA = req.A; // 中间件 A 的输出结果var retB = req.B; // 中间件 B 的输出结果var retC = req.C; // 中间件 C 的输出结果// ... 其余程序逻辑
});// ...
// 返回 router 供 app 使用
module.exports = router;
复制代码

通过 express.Router,控制器与中间件的代码紧密的联系在一起,并且避免了传递 app 的潜在风险。同时,一个 router 就是一个完整的功能模块,不需要任何装配就可以执行。这一点对于单元测试来说非常简单。

 

 

2.5.3 中间件重用

express.Router 可以认为是一个迷你的 app,它拥有一个独立的中间件队列。这个特性可以用来共享一些常用的中间件,例如:

例:parseBook方法是个中间件方法。

复制代码
var bookRouter = express.Router();app.use('/books', bookRouter);//路由指定中间件
bookRouter.use(parseBook);//如下三个控制器都会经过 parseBook 中间件。
bookRouter.get('/books/:bookId', viewBook);
bookRouter.get('/books/:bookId/edit', editBook);
bookRouter.get('/books/:bookId/move', moveBook);app.get('/other_link', otherController); // 不会经过 parseBook 中间件。
复制代码

 

例:Restful的Router。

复制代码
var bookRouter = express.Router();
bookRouter.route('/books/:bookId?').get(function (req, res) {// ...}).put(function (req, res) {// ...}).post(function (req, res) {// ...}).delete(function (req, res) {// ...})
复制代码

 

 

app.route

假定app是Express的实例对象,Express 4.0为该对象提供了一个route属性。app.route实际上是express.Router()的缩写形式,直接挂载到根路径。

复制代码
app.route('/login').get(function(req, res) {res.send('this is the login form');}).post(function(req, res) {console.log('processing');res.send('processing the login form!');});
复制代码

 

 

 

 

2.6 request对象

使用req.query解析http查询字符串

复制代码
// GET /search?q=tobi+ferret
req.query.q
// => "tobi ferret"
// GET /shoes?order=desc&shoe[color]=blue&shoe[type]=converse
req.query.order
// => "desc"req.query.shoe.color
// => "blue"req.query.shoe.type
// => "converse"
复制代码

 

 

使用req.params获取url中的参数

复制代码
app.get('/blog/:year/:month/:day/:title', function (req, res) {var fileName = './blogs/' + req.params.year + '-' +req.params.month + '-' +req.params.day + '-' +req.params.title + '.md';fs.readFile(fileName, 'utf-8', function (err, data) {if (err) {res.send(err);}res.send(data);});
});
复制代码

 

 

获取请求中参数的通用方法

req.param(name)

复制代码
// ?name=tobi
req.param('name')
// => "tobi"// POST name=tobi
req.param('name')
// => "tobi"// /user/tobi for /user/:name
req.param('name')
// => "tobi"
复制代码

 

 

request.ip

request.ip属性用于获得HTTP请求的IP地址。

 

request.files

request.files用于获取上传的文件。

 

 

 

2.7 response对象

response.redirect方法

response.redirect方法用于网址的重定向。

response.redirect("/hello/anime");
response.redirect("http://www.example.com");
response.redirect(301, "http://www.example.com");

 

 

response.sendFile方法

response.sendFile方法用于发送文件。

response.sendFile("/path/to/anime.mp4");

 

 

response.render方法

response.render方法用于渲染网页模板。

app.get("/", function(request, response) {response.render("index", { message: "Hello World" });    //将message变量传入index模板,渲染成HTML网页。
});

 

 

 

 

2.8 使用EJS模板

EJS是一个JavaScript模板库,用来从JSON数据中生成HTML字符串。EJS的优点是将会带给你明确、维护性良好的HTML代码结构。EJS模板以”.ejs”为后缀。

 

2.8.1 基本应用

数据

{title: 'Cleaning Supplies',supplies: ['mop', 'broom', 'duster']
}

 

 

模板

复制代码
<h1><%= title %></h1>
<ul>
<% for(var i=0; i<supplies.length; i++) {%>
    <li><%= supplies[i] %></li>
<% } %>
</ul>
复制代码

 

 

用数据渲染模板,WEB的显示结果:

wps_clip_image-27354

 

 

 

2.8.2 Include功能

EJS提供了模版包含(include)的功能,可以include不同的页面部件,组合在一起。

其语法为:<% include foot.ejs %>

 

 

2.8.3 其他

EJS实际可以不依赖Express而独立使用的。甚至在浏览器中也有很好的应用。

 

 

 

3 Express所需要的工具组件

Express 4.x 的版本做了很多改进,将很多功能分离出去,以第三方组件的形式为Express提供了更多的功能。同时Express也会有更好的扩展性。

 

 

3.1 body-parser

body-parser是Node.js的body解析中间件。用于解析HTTP报文body部分的数据。

body-parser无法处理multipart的body,对于multipart,可能需要使用如下模块:

· busboy connect-busboy

· multiparty connect-multiparty

· formidable

· multer

其他body解析器:

· body

· co-body

 

 

API示例

复制代码
var express    = require('express')
var bodyParser = require('body-parser')var app = express()// 解析application/x-www-form-urlencoded
app.use(bodyParser.urlencoded())// 解析application/json
app.use(bodyParser.json())// 解析application/vnd.api+json 作为json
app.use(bodyParser.json({ type: 'application/vnd.api+json' }))app.use(function (req, res, next) {console.log(req.body) // populated!next()
})
复制代码

 

 

 

bodyParser.json(options)

返回一个解析json的中间件。该解析器可以接受Unicode编码的请求体,可以作自动解压缩gzip,或解码。

选项:

  • strict - 仅解析对象和数组。(default: true)
  • inflate - 设置是否解压被压缩的body (default: true)
  • limit - request的body的最大长度。 (default: <100kb>)
  • reviver - 传递给JSON.parse()
  • type - 解析的类型。(default: json)
  • verify - 判定body内容的函数。

type参数将直接传递给 type-is 库。该值可以是一个扩展名(如:json),一个mime类型(如:application/json),或者一个带通配符的mime(如:*/json)

若提供verify 参数,其函数形式为verify(req, res, buf, encoding),buf是Buffer类型,是请求体。encoding 是请求的编码。解析会被抛出的错误而中止。

reviver 参数会被直接传递给 JSON.parse方法获取其第二个参数。可以在MDN 的文档中找到更多相关资料。

 

bodyParser.raw(options)

返回的中间件,中间件将body作为Buffer。该解析器可以作自动解压缩gzip或者解码。

选项:

  • inflate - 同bodyParser.json (default: true)
  • limit - 同bodyParser.json (default: <100kb>)
  • type - 同bodyParser.json (default: application/octet-stream)
  • verify - 同bodyParser.json

type参数将直接传递给 type-is 库。该值可以是一个扩展名(如:bin),一个mime类型(如:application/octet-stream),或者一个带通配符的mime(如:application/*)

 

bodyParser.text(options)

返回的中间件,中间件将body作为字符串。该解析器可以作自动解压缩gzip或者解码。

选项:

  • defaultCharset - 若没有指定content-type,该值为默认字符集。 (default: utf-8)
  • inflate - 同bodyParser.json。 (default: true)
  • limit - 同bodyParser.json。 (default: <100kb>)
  • type - 同bodyParser.json。 (default: text/plain)
  • verify - 同bodyParser.json。

type参数将直接传递给 type-is 库。该值可以是一个扩展名(如:txt),一个mime类型(如:text/plain),或者一个带通配符的mime(如:text/*)

 

bodyParser.urlencoded(options)

返回一个拥有解析urlencoded 请求体的中间件。该解析器可以接受Unicode编码的请求体,该可以作自动解压缩gzip,或解码。

选项:

  • extended - 使用qs模块解析扩展的语法。(default: true)
  • inflate - 同bodyParser.json。  (default: true)
  • limit - 同bodyParser.json。  (default: <100kb>)
  • type - 同bodyParser.json。 (default: urlencoded)
  • verify - 同bodyParser.json。

extended 参数允许选择解析urlencoded 数据的库,当为false时,使用querystring 库解析,当为true时,使用qs库解析。“扩展”的语法允许富对象和数组编码为urlencoded 格式,允许类JSON表达式。更多信息请参考qs库

type参数将直接传递给 type-is 库。该值可以是一个扩展名(如:urlencoded),一个mime类型(如:application/x-www-form-urlencoded),或者一个带通配符的mime(如: */x-www-form-urlencoded)

 

req.body

HTTP中报文体的对象。

例:

复制代码
var express = require('express');var app = express();app.use(express.bodyParser());app.all('/', function(req, res){res.send(req.body.title + req.body.text);
});app.listen(3000);
复制代码

 

 

 

 

3.2 cookie-parser

cookieParser中间件,用于分析和处理req.cookies的cookie数据。

 

 

 

3.3 express-session

express-session是一个为Express提供的 session中间件。

复制代码
var express = require('express')
var session = require('express-session')var app = express()app.use(session({secret: 'keyboard cat'}))
复制代码

 

 

session(options)

为session设置存储选项。session ID存储于cookie,其他数据不会被存储在cookie中。

  • name - cookie的名称(默认: 'connect.sid')
  • store - session的存储实例。
  • secret - session cookie通过secret 加密。
  • cookie - session相关cookie的设置项。(默认: { path: '/', httpOnly: true, secure: false, maxAge: null })
  • genid - session ID的生成函数。 (默认: 使用uid2库。)
  • rolling - 强制对每个response的cookie设置过期日期。(默认:false)
  • resave - 强制session为被保存的。(默认:true)
  • proxy - 信任反向代理,当时也secure cookies时候,当该项为true,则"x-forwarded-proto"报文头将会被使用。当设置为false时,所有的报文头都会被忽略。若不设置,则使用express的"trust proxy"设置。(默认:undefined)
  • saveUninitialized - 强制session以"uninitialized"被保存到仓库。会话是未初始化的时不能被修改。这对实现登录会话是非常有用的。(默认:true)
  • unset - 通过该选项,删除req.session或将其设为null后,设置req.session的结局。若为”keep”,则session将会在仓库中维持着,但无法被修改;若为”destory”则将销毁仓库中的session。(默认:'keep')

 

options.genid

对新session生成session ID。提供一个函数。函数返回一个字符串作为session ID。函数有一个req参数,在生成ID时,可以使用一些值附加到req上。

注意:session ID需要唯一。

例:

app.use(session({genid: function(req) {return genuuid(); // use UUIDs for session IDs},secret: 'keyboard cat'
}))

 

 

 

Cookie选项

请注意 secure: true 是一个被推荐的选项。然而,这需要https的支持。HTTPS需要安全的Cookie。如果secure 被设置了,若使用HTTP访问网站程序时,则cookie将不会被设置。如果你的node.js在代理之后,且使用了 secure: true ,被需要设置,则需要在express中设置"trust proxy" 。

复制代码
var app = express()app.set('trust proxy', 1) // trust first proxy

app.use(session({secret: 'keyboard cat', cookie: { secure: true }
}))
复制代码

 

在生产环境下,使用安全cookie。可以为了开发测试,如下是一个的设置基于NODE_ENV的例子:

复制代码
var app = express()var sess = {secret: 'keyboard cat'cookie: {}
}if (app.get('env') === 'production') {app.set('trust proxy', 1) // trust first proxysess.cookie.secure = true // serve secure cookies
}app.use(session(sess))
复制代码

 

 

cookie.maxAge默认是null的,即expires没有配置,所以cookie用于浏览器的会话cookie。当时用户关闭浏览器,会话cookie就会被移除。

 

 

req.session

存储或访问session数据。

示例:

复制代码
app.use(session({ secret: 'keyboard cat', cookie: { maxAge: 60000 }}))
app.use(function(req, res, next) {var sess = req.sessionif (sess.views) {sess.views++res.setHeader('Content-Type', 'text/html')res.write('<p>views: ' + sess.views + '</p>')res.write('<p>expires in: ' + (sess.cookie.maxAge / 1000) + 's</p>')res.end()} else {sess.views = 1res.end('welcome to the session demo. refresh!')}
})
复制代码

 

 

 

session.regenerate()

调用该方法重新生成session,一旦完成一个SID,Session实例将会在req.session中被初始化。

req.session.regenerate(function(err) {// 此处将使用一个新的session。
})

 

 

 

session.destroy()

销毁session,移除req.session,将会重新生成下一个request。

req.session.destroy(function(err) {// 此处无法使用session
})

 

 

session.reload()

重新加载session数据。

req.session.reload(function(err) {// session升级
})

 

 

session.save()

req.session.save(function(err) {// session被保存
})

 

 

session.touch()

更新maxAge属性。该方法不需要调用,session中间件会自动做这件事情。

 

req.session.cookie

每个session必须有一个唯一的cookie对象对应。

  • req.session.cookie.expires  用于cookie的过期设置。若req.session.cookie.expires设置为false,则使得cookie仅保持用户代理。
  • req.session.cookie.maxAge  为session.cookie的剩余时间,单位为毫秒。

 

例:设置并查看cookie.maxAge的时间

var hour = 3600000
req.session.cookie.expires = new Date(Date.now() + hour)
req.session.cookie.maxAge = hour

 

30秒之后,req.session.cookie.maxAge返回剩余时间。

req.session.cookie.maxAge // => 30000

 

 

 

 

Session仓库的实现

每个session仓库必须实现如下方法:

  • .get(sid, callback)
  • .set(sid, session, callback)
  • .destroy(sid, callback)

推荐实现也实现如下方法:

  • .length(callback)
  • .clear(callback)

 

例:以下是一个redis的实现。

https://github.com/visionmedia/connect-redis

 

 

 

 

 

 

Express官方资料:

http://expressjs.com/

https://www.npmjs.org/package/express

https://github.com/visionmedia/expressjs.com

https://github.com/visionmedia/express#quick-start

 

body-parser相关参考资料:

https://github.com/expressjs/body-parser

https://www.npmjs.org/package/body-parser

 

cookie-parser相关参考资料:

https://github.com/expressjs/cookie-parser

https://www.npmjs.org/package/cookie-parser

 

express-session相关参考资料:

https://github.com/expressjs/session

https://www.npmjs.org/package/express-session

 

关于expressjs更多的组件请在如下地址搜索:

https://github.com/expressjs

https://www.npmjs.org/

 

感谢如下博客作者为我们提供的学习资料:

http://javascript.ruanyifeng.com/nodejs/express.html

http://www.cnblogs.com/moonpanda/p/3669735.html

http://blog.segmentfault.com/nark/1190000000488358

http://lostjs.com/2014/04/24/upgrade-express-4/

https://github.com/visionmedia/express/wiki/Migrating-from-3.x-to-4.x

http://www.cnblogs.com/yuanzm/p/3770986.html

http://my.oschina.net/tangdu/blog/282207

http://www.cnblogs.com/ahl5esoft/p/3769781.html

http://www.90it.net/topic/web/node

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. Win10 安装node.js

    安装node.js步骤:Node.js简介 简单的说 Node.js 就是运行在服务端的 JavaScript。Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。Node.js 的包管理器 npm,是全球最大的开源库生态系统。 下载…...

    2024/4/24 13:14:10
  2. Node.js安装及环境配置

    一、安装环境1、本机系统:Windows 10 Pro(64位) 2、Node.js:v6.9.2LTS(64位)二、安装Node.js步骤1、下载对应你系统的Node.js版本:https://nodejs.org/en/download/ 2、选安装目录进行安装 3、环境配置 4、测试三、前期准备1、Node.js简介 简单的说 Node.js 就是运行在服…...

    2024/4/27 6:56:50
  3. 如何配置Node.js与express

    如何配置Node.js与express 本节将介绍如何配置node与express 配置Node.js 1、下载Node.js安装包Node.js下载地址2、按照安装包的流程一步一步的下去一直点击Next就OK啦3、在终端里面可以看到所装的Node的版本 输入以下语句:4、使用Node.js创建一个应用 (1)使用 http.createS…...

    2024/4/24 13:14:04
  4. node.js+express+vue+mysql搭建web服务(一)

    今天试了一下nodejs搭建一个web服务,感觉还是蛮简单的 下面记录一下操作步骤 1安装nodejs 2安装express $npm install express -g $npm install express-generator -g3命令行指到项目存放地,执行以下操作,会自动创建项目目录 express Blog4进入项目执行 npm install5启动i项目…...

    2024/4/24 13:14:04
  5. springboot前后端分离之node.js环境搭建

    参考自链接:https://www.cnblogs.com/zhouyu2017/p/6485265.htmlNode.js安装及环境配置之Windows篇一、安装环境1、本机系统:Windows 10 Pro(64位) 2、Node.js:v6.9.2LTS(64位)二、安装Node.js步骤1、下载对应你系统的Node.js版本:https://nodejs.org/en/download/ 2、选…...

    2024/4/24 13:14:02
  6. 【深入浅出Node.js系列三】深入Node.js的模块机制

    1 Node.js模块的实现 之前在网上查阅了许多介绍Node.js的文章,可惜对于Node.js的模块机制大都着墨不多。在后续介绍模块的使用之前,我认为有必要深入一下Node.js的模块机制。1.1 CommonJS规范 早在Netscape诞生不久后,JavaScript就一直在探索本地编程的路,Rhino是其代表产物。无…...

    2024/4/24 13:14:01
  7. python node.js快速入门

    一:简述node.js以及安装1.那么什么是node.js?简单的说node.js就是运行在服务端的JavaScript,node.js是基于Chrome JavaScript 运行时建立的一个平台;node.js是一个时间驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行JavaScript的速度非常快,性能非常好。2.了…...

    2024/4/24 13:14:01
  8. Node.js中 express-session的奇怪问题

    var session = require(express-session);app.use(cookieParser()); app.use(session({ secret: 123 })); -第71行登录以后访问的时候有时候会报这样的错误: The last 64k of the output generated by the node.exe process to stderr is shown below: Wed, 26 Jul 2017 15:5…...

    2024/4/24 13:13:59
  9. Node.js利用Express框架搭建小型网站

    http://blog.csdn.net/kkkkkxiaofei/article/details/31393863一、Express环境搭建Express是Node.js下的一个轻量级Web框架,有了它我们就可以轻松的架构出一个个人小型网站,Express框架安装步骤如下:1.进入npm目录,执行 npm install express这里我有必要说明一下:Expres框…...

    2024/4/24 13:13:59
  10. eclipse node.js

    说明:本人OS为64位windows7 Eclipse开发环境搭建前提条件:1)Node.js已安装ok,环境变量已配置,可以使用node -v来校验是否安装和配置成功(打开cmd命令窗口,输入node -v,如果正确安装正确,则会输出安装的Node.js版本号);成功了以后,在命令窗口下执行命令: npm -v ,…...

    2024/4/24 13:13:58
  11. node.js express使用websocket

    这个效果我也是翻了好长时间的资料,测试才成功的,反正成功,大家看看吧首先你需要安装socket.io模块[javascript] view plain copynpm install socket.io --save 然后打开express的app.js将模块引入,在12行左右的[javascript] view plain copyvar app = express(); 下面…...

    2024/5/3 22:12:59
  12. node.js搭建接口(一):使用express搭建服务器

    Express是一个基于 Node.js 平台,快速、开放、极简的 web 开发框架,目前还不太了解express到底是什么,希望以后能来补充。安装首先假定你已经安装了 Node.js,接下来为你的应用创建一个目录,然后进入此目录并将其作为当前工作目录。$ mkdir myapp $ cd myapp通过 npm init …...

    2024/5/3 16:21:11
  13. node.js基本工作原理及流程

    概述Node.js是什么Node 是一个服务器端 JavaScript 解释器,用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞I/O 模型而得以轻量和高效,非常适合在分布式设备上运行数据密集型的实时应用。 Node.js 是一个可以让 JavaScript 运行在浏览器之外的…...

    2024/4/15 4:07:53
  14. 用node.js+express自建网站发布静态网页

    引子最近,需要发布自己创建一个web server发布几个html页面。之前用过node.js,知道 express,但是就是没有自己亲自动手配置一个web server。在网上逛了逛,最终搞定,步 骤如下。安装node这个网上有很多,搜索一下就可以了,windows,ubuntu,各个平台的都有。安装Express并…...

    2024/4/17 16:33:45
  15. Node.js实战项目--简单的项目发布系统

    Node.js实战项目–简单的项目发布系统本章项目是使用express+mongodb制作一个简单的项目发布系统。项目前准备安装node.js 安装express 安装mongoDB 安装studio 3T项目结构初始化第一步:首先新建express站点,express publish-system -e -c less,这些我们新建的项目名称是…...

    2024/4/18 17:38:20
  16. Node.js+Express+Socket.io环境搭建

    1、先到官方的网站下载nodejs安装包,zip或者msi都行,后者是直接双击安装的,比较省事, 我比较喜欢把复杂的问题简单化。 下载地址:nodejs中文网,一般不建议选择最新版,防止不稳定之类的问题,一般我都是选择前2-3个版本。这么多怎么选择,根据服务器的系统的版本选择,x6…...

    2024/4/19 16:04:23
  17. phaChat聊天室(Node.js+express+mysql+socket)

    一个基于 node.js 搭建的web聊天系统node.js express mysql socket简介一个简单的 web 聊天室, 采用 node.js 编写,基于 express + mysql + socket 实现的在线多人web 聊天系统,包括用户的登陆注册,用户的个 人信息修改,目的是为了更加深入学习了解 node.js 和 websocket 技…...

    2024/4/15 4:07:56
  18. node.js express使用log4js记录日志

    创建log.jsvar log4js = require(log4js); log4js.configure({appenders: [{type: console,category: "console"}, //控制台输出{type: "dateFile",filename: logs/log.log,pattern: "_yyyy-MM-dd",alwaysIncludePattern: false,category: dateF…...

    2024/4/15 4:07:54
  19. 【Node.js】WebStorm+Node.js开发环境的配置

    WebStorm是作为JS开发IDE存在的,并且支持流行的Node.js以及JQuery等js框架。而Node.js简单说就是一个JS类库并且配备有Google的V8 js引擎来解析和执行js脚本。那WebStorm+Node.js这样一个组合,用来开发基于Node.js平台的应用是最方便不过的了,并且可以知道WebStorm这个IDE环…...

    2024/4/24 13:13:56
  20. [转] Node.js 框架比较: Express vs. Koa vs. Hapi

    英文原文:Node.js Framework Comparison: Express vs. Koa vs. Hapi 作者:Jonathan 译者:戴嘉华 原文地址:Node.js 框架比较: Express vs. Koa vs. Hapi 1 IntroductionExpress.js is the most popular Node.js web application framework used today. It seems to be t…...

    2024/4/24 13:13:59

最新文章

  1. R语言计算特定列的和(自备)

    R语言长款数据转换&#xff08;自备&#xff09;_r语言宽数据转换成长数据-CSDN博客 数据 rm(list ls()) library(ggplot2) library(ggpubr) library(cowplot) data <- iris##鸢尾花数据集 #[1] "Sepal.Length" "Sepal.Width" "Petal.Length&…...

    2024/5/4 10:23:40
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 第十一届蓝桥杯物联网试题(省赛)

    对于通信方面&#xff0c;还是终端A、B都保持接收状态&#xff0c;当要发送的数组不为空再发送数据&#xff0c;发送完后立即清除&#xff0c;接收数据的数组不为空则处理&#xff0c;处理完后立即清除&#xff0c;分工明确 继电器不亮一般可能是电压不够 将数据加空格再加\r…...

    2024/5/4 4:09:25
  4. 【计算机网络】基础知识复习-第一章-计算机网络基础

    第一章 计算机网络基础 以传输信息为主要目的&#xff0c;利用通信线路将各计算机系统的计算机连接起来的计算机群称为计算机通信网络。   凡是将地理位置不同&#xff0c;并具有独立功能的多个计算机系统通过通信设备和线路连接起来&#xff0c;以适用的软件&#xff08;即…...

    2024/4/30 17:32:57
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/1 17:30:59
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/2 16:16:39
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/3 23:10:03
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/2 15:04:34
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/5/4 2:59:34
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/2 9:07:46
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57