VUE 调用 .net api session为null 的问题!!!(后端实现生成验证码)

(后端生成验证码)api实现功能.

apicode:

* _memoryCache.Set() get() 方法是 memoryCache的存取

关于memoryCache 的使用大家自行度娘

 [HttpPost]
        public async Task<FileContentResult> GetImgCode(sysUser_DynamicObjectHome returnObject)
        {
            //生成验证码
            var capt = new CaptchaHelper();

            var code = await capt.GenerateRandomCaptchaAsync();

            //将code存到客户本地memoryCache
            // returnObject.Mkey key是前端生成的guid每次更改验证码时更改
            _memoryCache.Set(returnObject.Mkey, code);

            var result = await capt.GenerateCaptchaImageAsync(code);

            return File(result.CaptchaMemoryStream.ToArray(), "image/png");
        }

注:CaptchaHelper.cs 类

public class CaptchaResult
    {
        /// <summary>
        /// CaptchaCode
        /// </summary>
        public string CaptchaCode { get; set; }

        /// <summary>
        /// CaptchaMemoryStream
        /// </summary>
        public MemoryStream CaptchaMemoryStream { get; set; }

        /// <summary>
        /// Timestamp
        /// </summary>
        public DateTime Timestamp { get; set; }
    }

    public interface ICaptchaHelper
    {
        // <summary>
        /// 生成随机验证码
        /// </summary>
        /// <param name="codeLength"></param>
        /// <returns></returns>
        Task<string> GenerateRandomCaptchaAsync(int codeLength = 4);

        /// <summary>
        /// 生成验证码图片
        /// </summary>
        /// <param name="captchaCode">验证码</param>
        /// <param name="width">宽为0将根据验证码长度自动匹配合适宽度</param>
        /// <param name="height">高</param>
        /// <returns></returns>
        Task<CaptchaResult> GenerateCaptchaImageAsync(string captchaCode, int width = 0, int height = 30);
    }

    public class CaptchaHelper : ICaptchaHelper
    {
        private const string Letters = "2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,J,K,L,M,N,P,Q,R,S,T,U,V,W,X,Y,Z";

        public Task<CaptchaResult> GenerateCaptchaImageAsync(string captchaCode, int width = 0, int height = 30)
        {
            //验证码颜色集合
            Color[] c = { Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Orange, Color.Brown, Color.DarkCyan, Color.Purple };

            //验证码字体集合
            string[] fonts = { "Verdana", "Microsoft Sans Serif", "Comic Sans MS", "Arial" };

            //定义图像的大小,生成图像的实例
            var image = new Bitmap(width == 0 ? captchaCode.Length * 25 : width, height);

            var g = Graphics.FromImage(image);

            //背景设为白色
            g.Clear(Color.White);

            var random = new Random();

            for (var i = 0; i < 100; i++)
            {
                var x = random.Next(image.Width);
                var y = random.Next(image.Height);
                g.DrawRectangle(new Pen(Color.LightGray, 0), x, y, 1, 1);
            }

            //验证码绘制在g中
            for (var i = 0; i < captchaCode.Length; i++)
            {
                //随机颜色索引值
                var cindex = random.Next(c.Length);

                //随机字体索引值
                var findex = random.Next(fonts.Length);

                //字体
                var f = new Font(fonts[findex], 15, FontStyle.Bold);

                //颜色  
                Brush b = new SolidBrush(c[cindex]);

                var ii = 4;
                if ((i + 1) % 2 == 0)
                    ii = 2;

                //绘制一个验证字符  
                g.DrawString(captchaCode.Substring(i, 1), f, b, 17 + (i * 17), ii);
            }

            var ms = new MemoryStream();
            image.Save(ms, ImageFormat.Png);

            g.Dispose();
            image.Dispose();

            return Task.FromResult(new CaptchaResult
            {
                CaptchaCode = captchaCode,
                CaptchaMemoryStream = ms,
                Timestamp = DateTime.Now
            });
        }

        public Task<string> GenerateRandomCaptchaAsync(int codeLength = 4)
        {
            var array = Letters.Split(new[] { ',' });

            var random = new Random();

            var temp = -1;

            var captcheCode = string.Empty;

            for (int i = 0; i < codeLength; i++)
            {
                if (temp != -1)
                    random = new Random(i * temp * unchecked((int)DateTime.Now.Ticks));

                var index = random.Next(array.Length);

                if (temp != -1 && temp == index)
                    return GenerateRandomCaptchaAsync(codeLength);

                temp = index;

                captcheCode += array[index];
            }

            return Task.FromResult(captcheCode);
        }

登录代码:login(点击登录时请求的接口中增加验证码验证功能)
 


//sysUser.SyncState 为请求当前接口的参数 当前输入的验证码
//sysUser.Mkey 上一个接口说道的key  前端生成的guid
//copy代码后 参数更改

            if (!(_memoryCache.Get<string>(sysUser.Mkey).ToLower() == sysUser.SyncState.ToLower()))
            {
                _memoryCache.Remove(sysUser.Mkey);

                return "验证码错误";
            }

vue:

//vue 增加打开页面执行生成code方法 

//自己在data中 增加 Mkey 

 beforeMount() {
    this.Mkey = this.guid();
  },
mounted() {
    this.SelectCode();
  },

//生成code方法(向后端请求接口 展现图片)

   SelectCode() {
      var self = this;
      let param = {};
      param.Mkey = this.Mkey;
      axios({
        method: post,
        url: 1/1/,
        data: param,
        responseType: "arraybuffer", // 最为关键
      })
        .then((response) => {
          self.src =
            "data:image/jpeg;base64," + self.arrayBufferToBase64(response.data);
        })
        .catch((error) => {});
    },
    arrayBufferToBase64(buffer) {
      var binary = "";
      var bytes = new Uint8Array(buffer);
      var len = bytes.byteLength;
      for (var i = 0; i < len; i++) {
        binary += String.fromCharCode(bytes[i]);
      }
      return window.btoa(binary);
    },

//生成guid方法

S4() {
      return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1);
    },
    guid() {
      return (
        this.S4() +
        this.S4() +
        "-" +
        this.S4() +
        "-" +
        this.S4() +
        "-" +
        this.S4() +
        "-" +
        this.S4() +
        this.S4() +
        this.S4()
      );
    },

//页面点击登录的方法时


          var self = this;

          let param = {};
//当前的key
          param.Mkey = this.Mkey;
//文本框输入的 验证码
          param.SyncState = this.loginForm.seccode;
//url 和请求方式(post get) 自需更改
          this.$request({
            url: this.$api.Login.Login.url,
            method: this.$api.Login.Login.method,
            data: param,
          })

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是前端实现上传PDF的步骤: 1. 首先需要安装并引入axios和cos-js-sdk-v5这两个库。 2. 在Vue组件中,创建一个input标签,用于选择文件: ```html <template> <div> <input type="file" ref="fileInput" @change="handleFileChange"> </div> </template> ``` 3. 在Vue组件中,创建一个方法来处理选择文件事件,获取选择的文件并调用后端接口获取COS授权信息: ```javascript import { ref } from 'vue' import axios from 'axios' import COS from 'cos-js-sdk-v5' export default { setup() { const fileInputRef = ref(null) const handleFileChange = () => { const file = fileInputRef.value.files[0] // 调用后端接口获取COS授权信息 axios.get('/api/getCosAuthInfo').then(res => { const data = res.data const cos = new COS({ SecretId: data.tmpSecretId, SecretKey: data.tmpSecretKey, SessionToken: data.sessionToken }) // 调用cos对象的putObject方法上传文件 const key = 'uploads/' + file.name // key是文件上传到COS的路径 cos.putObject({ Bucket: data.bucket, Region: data.region, Key: key, Body: file, onProgress: progressData => { // 上传进度回调 console.log('上传进度:' + progressData.percent) } }, (err, data) => { if (err) { console.error(err) } else { console.log('上传成功:', data.Location) } }) }).catch(err => { console.error(err) }) } return { fileInputRef, handleFileChange } } } ``` 4. 在上传文件之前,需要先在COS上创建一个文件夹,可以在COS控制台上手动创建或者使用SDK进行创建: ```javascript cos.putObject({ Bucket: data.bucket, Region: data.region, Key: 'uploads/', // 文件夹路径以 / 结尾 Body: '', onProgress: progressData => { console.log('创建文件夹进度:' + progressData.percent) } }, (err, data) => { if (err) { console.error(err) } else { console.log('创建文件夹成功:', data) } }) ``` 5. 至此,前端上传PDF的流程就完成了,最后就是需要在后端进行文件的处理和存储了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值