Nodejs 플러그인에는 "node-xlsx", nodemailer, "node-readbility", connect, "express-session", "basic-auth", bcryptjs, puppeteer, 악몽 등이 포함됩니다.
이 튜토리얼의 운영 환경: windows7 시스템, nodejs 버전 12.19.0, DELL G3 컴퓨터.
1. Node-xlsx는 Excel을 읽고 씁니다
Excel 가져오기 및 내보내기는 많은 시스템에서 발생하는 문제이며 NodeJS도 예외는 아닙니다. Excel 파일 읽기 및 쓰기
NodeJS에서는 파일 읽기 및 쓰기를 실현하기 위해 타사 도구인 node-xlsx 모듈을 사용합니다. 이 모듈은 2003 Excel(.xls) 형식과 2007 Excel 형식( .Excel 파일 가져오기
cnpm install node-xlsx --save
위 코드는 Excel 파일 읽기 작업을 완료했습니다. 이때 우리가 읽은 내용은 객체이며 해당 정보는 콘솔에서 볼 수 있습니다
Excel에 쓰기 작업
이제 데이터베이스의 테이블에서 정보를 읽고 로컬 컴퓨터에 저장하는 방법을 보여드리겠습니다. 코드는 다음과 같습니다
const xlsx=require('node-xlsx');const DBUtil=require('./utils/DBUtil.js');const fs=require('fs');const path=require('path');function readExcel(path){ var excel=xlsx.parse(path); return excel;}var obj=readExcel(path.join(__dirname,"./files/studentinfo.xls"));console.log(obj[0].data);
여기서는 Excel에 쓰는 것이 조금 더 번거롭다는 것을 알았습니다. 데이터베이스에서 얻은 결과를 재결합하여 Excel을 생성해야 합니다
Thinking: Express 프레임워크에서 생성된 Excel 파일이 사용자가 로컬로 다운로드하고 저장할 수 있도록 다음과 같다면 어떨까요?
2. nodemailer
nodejs를 사용하여 사용자에게 이메일을 보내는 방법도 많이 사용됩니다. 예를 들어, 사용자가 등록한 후 등록 정보가 사용자에게 전송되는 것을 자주 볼 수 있습니다. 이때 이 기능을 완료하려면 nodemailer의 타사 모듈을 사용해야 합니다. 구체적인 단계는 다음과 같습니다. 해당 모듈을 설치합니다
const excel=require('node-xlsx');const fs=require('fs');const path=require('path');const DBUtil=require('./utils/DBUtil.js');function writeExcel(){ var conn=DBUtil.getConn(); conn.query("select * from studentinfo",[],(err,result)=>{ if(err){ } else{ var excelArr=[]; var headerRow=[]; for(var i in result[0]){ headerRow.push(i); } excelArr.push(headerRow); for(var i=0;i<result.length;i++){ var temp=[]; for(var j=0;j<headerRow.length;j++){ temp.push(result[i][headerRow[j]]); } excelArr.push(temp); } try { var buff=excel.build([{name:'学生信息',data:excelArr}]); fs.writeFileSync(path.join(__dirname,"./files/01.xlsx"),buff); console.log("ok"); } catch (error) { console.log(err); } } }); conn.end();}writeExcel();
모듈을 가져옵니다. 코드를 완성하세요 : 송신 서버를 구성할 때 타사 서버나 내장 서버를 사용할 수 있습니다 : 보낸 콘텐츠를 템플릿으로 바꾸는 경우 위의 코드는 전송할 이메일의 내용을 객체로 캡슐화한 다음 템플릿 구문을 사용하여 문자열을 연결합니다. Thinking: 위의 이메일 내용에 대해 별도의 외부 txt 파일에 작성하고 그런 다음 String을 사용하여 객체를 대체하여 이 기능을 구현하는 방법은 무엇입니까? 3.child_process 하위 프로세스를 생성하고 쉘 스크립트를 실행할 수 있습니다. 4. node-readbility웹사이트 콘텐츠를 간단한 콘텐츠로 바꿔주는 플러그인입니다. 5.connect 실제로 Express에서도 이 플러그인을 사용하고 있으며, Connect를 사용하여 웹 프로그램을 작성할 수도 있습니다. 6.express-session세션을 사용하는 플러그인입니다. 기본값은 영구이며, Tomcat과 30분 차이가 있으므로 시간 초과를 직접 설정해야 합니다. 7. basic-auth 플러그인 은 가장 간단한 인증 방법으로 일반적으로 API 요청에 사용됩니다. 8.bcryptjs 플러그인(bcrypt 설치 과정에서 항상 오류가 보고됩니다.) 솔팅을 사용하여 해시 처리를 수행하는 데 사용됩니다. 9. 파충류 수집: (1) 정적 페이지 및 API 데이터 크롤링: request+cheerio/jsdom은 게시물을 요청하고 정보를 얻을 수 있는 요청 라이브러리입니다. Cherio와 같은 구문 분석을 위한 타사 구문 분석 라이브러리. js 동적 렌더링 페이지의 경우 jsdom 사용을 고려할 수 있지만 불행하게도 이는 동기식이며 결국 브라우저가 아닙니다. (2) 동적으로 렌더링된 페이지 크롤링 puppeteer: chromiun 브라우저를 사용하면 비동기 요청이 매우 효율적이고 브라우저 작동을 위한 API가 많이 열려 매우 편리합니다. : API는 전자에서 브라우저를 사용하는 것이 매우 편리합니다. 비록 사용해 본 적은 없지만 Puppeteer만큼 유연하지는 않습니다. : 동기화 때문에 사용을 포기하게 되었습니다. 셀레늄과 동일합니다. 10、moment.js 이것은 경량 형식 파싱 라이브러리입니다. 형식 파싱 함수를 직접 작성하려면 수십 줄의 함수 코드가 필요합니다. 이것을 사용하면 매우 편리합니다. 노드 관련 지식을 더 보려면 nodejs 튜토리얼을 방문하세요! ! 위 내용은 nodejs 플러그인이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!$ cnpm install nodemailer --asve
$ yarn add nodemailer
const nodemailer=require('nodemailer');var transport = nodemailer.createTransport({
service:"qq",
auth:{
user:"365055754@qq.com",
pass:"peshapwpokgvcahe"
}});var options={
from:"365055754@qq.com",
to:"lovesnsfi@live.com",
subject:"这是一封来自nodemailer发送的邮件信息",
text:"这是一封来自nodemailer发送的邮件信息"+(new Date()).toLocaleString(),
html:"<h2>这是一封来自<u>nodemail</u>的测试邮件···</h2>"};transport.sendMail(options,(err,info)=>{
if(err){
console.log(err);
}
else{
console.log(info);
}});
{ accepted: [ 'lovesnsfi@live.com' ],
rejected: [],
envelopeTime: 221,
messageTime: 830,
messageSize: 801,
response: '250 Ok: queued as ',
envelope: { from: '365055754@qq.com', to: [ 'lovesnsfi@live.com' ] },
messageId: '<2fbef9f1-1041-fd59-1111-0b987e8d81da@qq.com>' }