웹 프론트엔드 JS 튜토리얼 노드는 로그인 시 이미지 인증코드를 생성합니다.

노드는 로그인 시 이미지 인증코드를 생성합니다.

Jun 07, 2018 am 11:05 AM
node 이미지 인증 코드 인증코드

이번에는 로그인 시 사진 인증 코드를 생성할 수 있는 노드를 가져오겠습니다. 노드가 로그인 시 사진 인증 코드를 생성할 때 주의사항은 무엇인가요? 다음은 실제 사례입니다.

여기서 그래픽 확인 코드를 구현하기 위해 노드에서 모든 문자와 숫자를 지원할 수 있는 svg-captcha 모듈을 사용합니다. 모든 플랫폼에서 지원되며 사용이 매우 간단합니다.

1.

cnpm i svg-captcha --save
로그인 후 복사

를 설치합니다.

var svgCaptcha = require('svg-captcha');
로그인 후 복사

를 가져옵니다. 세션은 프런트 엔드 액세스 확인을 용이하게 하기 위해 쿠키에 저장됩니다.

cnpm i cookie-parser --save code><p style="text-align: left;"><code>cookie-parser ,作用是将获取到的session保存到cookie,方便前端访问验证

cnpm i cookie-parser --save

3-2 使用 cookie-parser

const cookieParase = require('cookie-parser');
app.use(cookieParase());
로그인 후 복사

这样就可以在项目里使用cookie了

3-3 获取验证码

// 获取验证码
 getCaptcha(req, res, next){
  var captcha = svgCaptcha.create({ 
   // 翻转颜色 
   inverse: false, 
   // 字体大小 
   fontSize: 36, 
   // 噪声线条数 
   noise: 2, 
   // 宽度 
   width: 80, 
   // 高度 
   height: 30, 
  }); 
  // 保存到session,忽略大小写 
  req.session = captcha.text.toLowerCase(); 
  console.log(req.session); //0xtg 生成的验证码
  //保存到cookie 方便前端调用验证
  res.cookie('captcha', req.session); 
  res.setHeader('Content-Type', 'image/svg+xml');
  res.write(String(captcha.data));
  res.end();
 },
로그인 후 복사

做到这只是实现了生成验证码的功能,那么要访问呢?

4.编写后台路由

// 获取验证码
router.get('/api/getCaptcha', function(req, res, next) {
 return api.getCaptcha(req, res, next);
})
로그인 후 복사

当前端调用 /api/getCaptcha 这个接口的时候,返回验证码信息,是svg格式

5.前端访问

<img src="/api/getCaptcha" alt="captcha" >
로그인 후 복사

但是现在我们又有需求了,当点击这个验证码的时候,验证码会刷新

6.实现点击验证码刷新

更改一下刚刚验证码的结果,给他加一个外层a标签,并给他绑定一个点击事件,我这里用了 vue ,所以是 @click ,其他框架同理.

<a href="#" rel="external nofollow" @click="editCaptcha">
  <img src="/api/getCaptcha" alt="" ref="imgYzm">
</a>
로그인 후 복사

点击事件 editCaptcha

editCaptcha () {
  this.$refs.imgYzm.src = '/api/getCaptcha?d='+Math.random()
},
로그인 후 복사

这样就实现了点击验证码刷新的问题

7.前端验证验证码

刚刚我们在后台得到了验证码,但是前端要怎么验证呢?

记得在3-2的时候我们安装了 cookie-parser3-2 cookie-parser를 사용하세요

let captcha = document.cookie.split('=')[1]
  if(this.yzm != captcha){
   return this.$message.warning('验证码错误')
  }
로그인 후 복사

이렇게 하면 프로젝트에서 쿠키가 사용됩니다

3-3 인증 코드 받기

rrreee

생성 기능만 구현합니다. 인증 코드가 있는데 무엇에 액세스하고 싶으신가요?

4. 백그라운드 라우팅 작성

rrreee

프런트엔드에서 /api/getCaptcha 인터페이스를 호출하면 svg 형식의 인증 코드 정보가 반환됩니다

5. -액세스 종료

rrreee

하지만 이제 다시 클릭해야 합니다. 코드 인증 시 인증코드가 새로고침됩니다

🎜6. 인증코드 새로고침 클릭 구현🎜🎜🎜지금 인증코드 결과를 변경하고 외부 라벨을 추가하고 바인딩합니다. 클릭 이벤트에 적용됩니다. 여기서는 vue를 사용하므로 @click입니다. 다른 프레임워크에도 동일하게 적용됩니다.🎜rrreee🎜Click 이벤트 editCaptcha code>🎜rrreee🎜이렇게 하면 클릭 인증이 됩니다. 코드 새로 고침 문제🎜🎜🎜7. 프론트엔드 인증 인증 코드🎜🎜🎜백그라운드에서 인증 코드를 받았는데, 프론트엔드에서 어떻게 인증하나요? 🎜🎜3-2에서 <code>cookie-parser를 설치하고 3-3에서 생성된 세션을 쿠키에 저장했다는 점을 기억하세요. 여기서 우리의 프런트 엔드는 이 쿠키에 액세스하여 검증을 받을 수 있습니다. . 🎜🎜🎜🎜🎜왜 쿠키에 저장해야 하나요? 백엔드에서 생성된 세션은 프런트엔드에서 액세스할 수 없기 때문에 액세스를 기다리면 보안이 전혀 없으므로 프런트엔드 액세스를 위해 쿠키에 복사본을 저장합니다. 🎜rrreee🎜로그인 확인 등을 위한 계정 및 비밀번호 확인 코드의 최종 프런트 엔드 입력에 대한 자세한 개요는 설명하지 않겠습니다. 구체적인 아이디어는 이것이다. 🎜🎜이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요! 🎜🎜추천 도서: 🎜🎜🎜ES6의 클래스를 사용하여 Vue를 모방하여 양방향 바인딩 만들기🎜🎜🎜🎜🎜vue.js+element-ui를 메뉴 트리 구조 만들기🎜🎜🎜

위 내용은 노드는 로그인 시 이미지 인증코드를 생성합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Chrome에 인증코드 이미지가 표시되지 않으면 어떻게 해야 하나요? Chrome에 인증코드 이미지가 표시되지 않으면 어떻게 해야 하나요? Mar 13, 2024 pm 08:55 PM

Google 크롬에 인증 코드 이미지가 표시되지 않으면 어떻게 해야 하나요? Google Chrome을 사용하여 웹페이지에 로그인할 때 인증 코드가 필요한 경우가 있습니다. 일부 사용자는 이미지 인증 코드를 사용할 때 Chrome에서 이미지 내용을 제대로 표시할 수 없다는 사실을 발견합니다. 무엇을 해야 합니까? 아래 편집기에서 Chrome 인증 코드가 표시되지 않는 문제를 해결하는 방법을 소개하겠습니다. 모든 분들께 도움이 되길 바랍니다! 방법 소개: 1. 소프트웨어를 입력하고 오른쪽 상단 모서리에 있는 "추가" 버튼을 클릭한 다음 아래 옵션 목록에서 "설정"을 선택하여 들어갑니다. 2. 새 인터페이스에 들어간 후 왼쪽의 "개인정보 설정 및 보안" 옵션을 클릭하세요. 3. 오른쪽의 '웹사이트 설정'을 클릭하세요.

휴대폰으로 인증코드를 받을 수 없는 이유는 무엇입니까? 휴대폰으로 인증코드를 받을 수 없는 이유는 무엇입니까? Aug 17, 2023 pm 02:49 PM

휴대폰으로 인증번호를 받지 못하는 경우는 네트워크 문제, 휴대폰 설정 문제, 이동통신사 문제, 개인 설정 문제 등으로 인해 발생합니다. 자세한 소개: 1. 네트워크 문제. 휴대폰이 위치한 네트워크 환경이 불안정하거나 신호가 약하여 인증 코드가 제때 전달되지 않을 수 있습니다. 2. 휴대폰 설정 문제. 휴대폰의 음성 기능이 실수로 꺼졌거나, 인증번호 발신번호가 블랙리스트에 추가되어 인증번호가 정상적으로 수신되지 않는 경우 3. 휴대폰 사업자의 문제일 수 있습니다. 오작동 또는 유지 관리로 인해 인증 코드가 제때에 전달되지 않는 경우 등

가상번호로 인증코드를 받을 수 있나요? 가상번호로 인증코드를 받을 수 있나요? Jan 02, 2024 am 10:22 AM

가상번호로 인증번호를 받으실 수 있습니다. 등록 시 기재한 휴대폰번호가 규정을 준수하고 휴대폰 번호가 정상적으로 연결될 수 있으면 SMS 인증번호를 받으실 수 있습니다. 다만, 가상휴대폰번호 이용시에는 주의가 필요합니다. 일부 웹사이트에서는 가상휴대폰번호 등록을 지원하지 않으므로 일반 가상휴대폰번호 서비스 제공업체를 선택하셔야 합니다.

Express를 사용하여 노드 프로젝트에서 파일 업로드를 처리하는 방법 Express를 사용하여 노드 프로젝트에서 파일 업로드를 처리하는 방법 Mar 28, 2023 pm 07:28 PM

파일 업로드를 처리하는 방법은 무엇입니까? 다음 글에서는 Express를 사용하여 노드 프로젝트에서 파일 업로드를 처리하는 방법을 소개하겠습니다. 도움이 되길 바랍니다.

PHP 이미지 처리 사례: 이미지의 인증코드 기능 구현 방법 PHP 이미지 처리 사례: 이미지의 인증코드 기능 구현 방법 Aug 17, 2023 pm 12:09 PM

PHP 이미지 처리 사례: 이미지의 인증 코드 기능을 구현하는 방법 인터넷의 급속한 발전과 함께 인증 코드는 웹 사이트 보안을 보호하는 중요한 수단 중 하나가 되었습니다. 인증코드는 영상인식 기술을 이용해 사용자가 실제 사용자인지 확인하는 인증 방식이다. 이 글에서는 PHP를 사용하여 이미지의 인증 코드 기능을 구현하는 방법과 코드 예제를 소개합니다. 소개 인증 코드는 임의의 문자가 포함된 사진입니다. 사용자는 인증을 통과하기 위해 사진에 있는 문자를 입력해야 합니다. 인증 코드를 구현하는 주요 프로세스에는 임의의 문자를 생성하고 문자를 그림으로 그리는 작업이 포함됩니다.

PHP 개발 가이드: 인증 코드 로그인 구현 PHP 개발 가이드: 인증 코드 로그인 구현 Jul 01, 2023 am 09:27 AM

인터넷의 발달과 스마트폰의 대중화로 인해 인증코드 로그인 기능을 채택하는 웹사이트와 애플리케이션이 점점 더 많아지고 있습니다. 인증번호 로그인은 보안을 강화하고 악의적인 공격을 방지하기 위해 올바른 인증번호를 입력하여 사용자의 신원을 확인하는 로그인 방식입니다. PHP 개발 시 간단한 인증코드 로그인 기능 구현은 복잡하지 않으며 다음 단계를 통해 완료할 수 있습니다. 데이터베이스 테이블 생성 먼저, 인증 코드 정보를 저장할 데이터베이스에 테이블을 생성해야 합니다. 테이블 구조에는 다음 필드가 포함될 수 있습니다. id: 자동 증가 기본 키 전화

PHP를 사용하여 새로 고칠 수 있는 이미지 확인 코드를 생성하는 방법 PHP를 사용하여 새로 고칠 수 있는 이미지 확인 코드를 생성하는 방법 Sep 13, 2023 am 11:54 AM

PHP를 사용하여 새로 고침 가능한 이미지 확인 코드를 생성하는 방법 인터넷이 발달하면서 악의적인 공격과 자동 기계 작동을 방지하기 위해 많은 웹사이트에서 사용자 확인을 위해 확인 코드를 사용하고 있습니다. 일반적인 확인 코드 유형 중 하나는 이미지 확인 코드로, 임의의 문자가 포함된 그림을 생성하고 사용자가 계속 진행하기 전에 올바른 문자를 입력하도록 요구합니다. 이 문서에서는 PHP를 사용하여 새로 고칠 수 있는 이미지 확인 코드를 생성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1단계: 인증 코드 이미지 생성 먼저 인증 코드 이미지를 생성해야 합니다.

Java API 개발에서 이미지 확인 코드를 구현하는 방법 Java API 개발에서 이미지 확인 코드를 구현하는 방법 Jun 18, 2023 am 09:22 AM

인터넷 기술의 급속한 발전과 함께 시스템 보안을 보장하기 위해 인증 코드는 모든 시스템의 필수적인 부분이 되었습니다. 그 중 사진인증코드는 사용 편의성과 보안성 때문에 개발자들이 선호하는 방식이다. 이 글에서는 JavaAPI 개발에서 이미지 검증 코드를 구현하는 구체적인 방법을 소개합니다. 1. 사진인증코드란 사진을 통해 사람과 기계가 인증하는 방식입니다. 일반적으로 숫자, 문자, 기호 등이 포함된 그림의 무작위 조합으로 구성되어 시스템의 보안을 향상시킵니다. 작동 원리는 다음과 같습니다

See all articles