js+h5 canvas 이미지 인증 코드 구현
실현 효과
1.기술 사용
원생 js 기술+html 5 canvas 그림
Math.random()함 수 를 이용 하여 색상 문자열 을 무 작위 로 생 성 합 니 다. 장애물
인증 코드 를 클릭 하면 인증 코드 도안 을 변경 할 수 있 습 니 다.
2.사용 절차
1.html+css
코드 는 다음 과 같 습 니 다(예시).
<div class="login_code_box">
<div class="login_code">
<input type="text" name="login_code" id="login_code" placeholder=" ">
</div>
<canvas id="canvas" >
</canvas>
<!-- <img src="" alt="" title=" ? " class="login_code_img" > -->
</div>
#canvas{
width: 130px;
height: 45px;
display: inline-block;
border: 1px solid #c9c9c9;
border-radius: 5px;
}
2.js코드 는 다음 과 같 습 니 다(예시).
//
let canvas=document.getElementById('canvas')//
let show_num=[]//
//
function randomColor(){
var r= Math.floor( Math.random()*256);
var g= Math.floor( Math.random()*256);
var b= Math.floor( Math.random()*256);
return "rgb("+r+","+g+","+b+") "
}
//
function draw(show_num){
let canvas_clientWidth=document.getElementById('canvas').clientWidth//
let canvas_clientHeight=document.getElementById('canvas').clientHeight//
let context = canvas.getContext("2d")// context :
canvas.width=canvas_clientWidth
canvas.height=canvas_clientHeight
let str="A,B,C,E,F,G,H,J,K,L,M,N,P,Q,R,S,T,W,X,Y,Z,1,2,3,4,5,6,7,8,9,0,q,w,e,r,t,y,u,i,o,p,a,s,d,f,g,h,j,k,l,z,x,c,v,b,n,m";
let astr=str.split(',');//
let sLength=astr.length;//
for (let i = 0; i <= 3; i++) {
let j=Math.floor(Math.random()*sLength);//
let deg=Math.random()*30*Math.PI/180;//0-30
let text=astr[j];//
show_num[i]=text//
let x=10+i*20//x
let y=20+Math.random()*8//y
//
context.font='bold 23px '
context.translate(x, y);
context.rotate(deg);
context.fillStyle = randomColor();
context.fillText(text,0,0)
context.rotate(-deg)
context.translate(-x,-y)
}
//
for(let i=0;i<=30;i++){
context.strokeStyle=randomColor()//
context.beginPath();//
let m=Math.random()*canvas_clientWidth;
let n=Math.random()*canvas_clientHeight;
context.moveTo(m,n)//
context.lineTo(m + 1, n + 1);// ,
context.stroke();//
}
//
for (let i = 0; i < 8; i++) {
context.strokeStyle=randomColor()
context.beginPath()
context.moveTo(Math.random()*canvas_clientWidth,Math.random()*canvas_clientHeight);
context.lineTo(Math.random()*canvas_clientWidth,Math.random()*canvas_clientHeight)
context.stroke()
}
}
draw(show_num)
console.log(show_num);
canvas.onclick=()=>{
draw(show_num)
console.log(show_num);
}
총결산canvas 캔버스 를 만 들 고 랜 덤 함 수 를 이용 하여 랜 덤 색상 을 만 듭 니 다.
draw()함수,인증 코드 생 성 에 사용 합 니 다.문자열 구분 저장 배열
인증 코드 를 만 드 는 갯 수 를 반복 합 니 다.
현재 문자열 의 위치 이동 및 회전 각도 텍스트 스타일 등
무 작위 함수 생 성 작은 점 및 선분 context.stroke()는 위 에서 정 의 된 색상 변위 길이 의 경 로 를 그리고 canvas 캔버스 에 표시 합 니 다.
캔버스 캔버스 를 누 르 면 인증 코드 내용 을 다시 생 성 할 수 있 습 니 다.
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
[2022.04.19] 자바스크립트 this - 생성자 함수와 이벤트리스너에서의 this18일에 this에 대해 공부하면서 적었던 일반적인 함수나 객체에서의 this가 아닌 오늘은 이벤트리스너와 생성자 함수 안에서의 this를 살펴보기로 했다. new 키워드를 붙여 함수를 생성자로 사용할 때 this는...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.