六位验证码实现


<template>
  <div>
    <div class="code-input-main">
      <div class="code-input-main-item">{{getCode[0]}}</div>
      <div class="code-input-main-item">{{getCode[1]}}</div>
      <div class="code-input-main-item">{{getCode[2]}}</div>
      <div class="code-input-main-item">{{getCode[3]}}</div>
      <div class="code-input-main-item">{{getCode[4]}}</div>
      <div class="code-input-main-item">{{getCode[5]}}</div>
      <input class="code-input-input" v-model="code" maxlength="6" type="number" />
    </div>
    <div @click="submit" >提交</div>
  </div>
</template>
<script>
export default {
  name: "CodeInput",
  data() {
    return {
      code: '',
      passwordLength: 6
    }
  },
  computed: {
    getCode() {

      return this.code;
    }
  },
  methods: {
    submit() {
      console.log(this.code.substring(0, 6));
    }
  }

}

</script>
<style scoped>
.code-input-input {

  height: 49px;
  position: absolute;
  width: 100%;
  outline: none;
  background: transparent;
  color: transparent;
  border: none;
  text-shadow: 0 0 0 transparent;
  width: 300%;
  margin-left: -100%;
}

.code-input-main {

  background: red;
  display: flex;
  flex-direction: row;
  justify-content: space-around;
}

.code-input-main-item {
  font-family: time-font-myself;
  width: 16px;
  height: 40px;
  opacity: 0.8;
  border-bottom: solid blue 1px;
  margin: 5px;
  text-align: center;
  padding-bottom: 0;
  font-size: 30px;
  color: green;
}

.code-input-input {
  height: 44px;
  position: absolute;
  outline: none;
  color: transparent;
  text-shadow: 0 0 0 transparent;
  width: 300%;
  margin-left: -100%;
}

</style>


</style>

随机生成6位图片验证码. /// <summary> /// PicHandler1 的摘要说明 /// </summary> public class PicHandler1 : IHttpHandler, IRequiresSessionState { private string mCheckNo = string.Empty; protected ImgBuilder _ImgBuilder = new ImgBuilder(); protected VryImgGen _ImgBuilderNew = new VryImgGen(); private string _text = string.Empty; private string _font = "宋体"; private int _fontSize = 8; private int _padding = 2; public void ProcessRequest(HttpContext context) { mCheckNo = DisCheckNo(); context.Session["CheckCode"] = mCheckNo; this._ImgBuilder.FontSize = this._fontSize; this._ImgBuilder.Padding = this._padding; if (!string.IsNullOrEmpty(this._font)) { this._ImgBuilder.Fonts = new string[] { this._font }; } this._ImgBuilderNew.ChaosWight = 40; this._ImgBuilderNew.FontSize = 25; this._ImgBuilderNew.Padding = 3; System.Drawing.Bitmap image = this._ImgBuilderNew.CreateImage(mCheckNo); System.IO.MemoryStream ms = new System.IO.MemoryStream(); image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg); context.Response.ClearContent(); context.Response.ContentType = "image/Jpeg"; context.Response.BinaryWrite(ms.ToArray()); context.Session["CheckCode"] = mCheckNo.ToString(); //如果没有实现IRequiresSessionState,则这里会出错,也无法生成图片 context.Response.End(); } //验证码生成 protected string DisCheckNo() { string hash = HashCode.GetNext(); string CheckNo = string.Empty; Random rd = new Random(DateTime.Now.Millisecond); for (int i = 0; i < 6; i++) { CheckNo += hash.Substring(rd.Next(1, hash.Length - 1), 1); } CheckNo = CheckNo.Replace("0", rd.Next(1, 9).ToString()); CheckNo = CheckNo.Replace("o", rd.Next(1, 9).ToString());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值