代码改变世界

微网页html+ashx提交数据

2017-05-04 14:47  穷极思变  阅读(512)  评论(0)    收藏  举报

前端页面

<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="format-detection" content="telephone=no">
    <title></title>
    <link href="css/mobile.css" rel="stylesheet" type="text/css">
    <link rel="stylesheet" href="https://res.wx.qq.com/open/libs/weui/0.3.0/weui.css" />
    <script language="javascript" type="text/javascript" src="js/jquery.min.js"></script>
</head>
<body mpa-version="4.1.3" mpa-extension-id="ibefaeehajgcpooopoegkifhgecigeeg">
    <input id="hiddenImage" type="hidden" />
    <div class="proj_name" style="font-size:18px; line-height: 1.6em; ">XXXX</div>
    <!-- include header -->
    <div style="margin: 20px auto 15px auto; width: 95%; max-width: 500px; ">

    </div>
    <div class="ques_info" style="margin: 15px auto 15px auto; width: 95%; max-width: 500px; ">
        <table width="95%" border="0" cellspacing="5" cellpadding="5" align="center" style="margin-top:10px;">
            <tbody>
                <tr>
                    <td nowrap="" style="width:68px;font-weight:bold;">姓名:</td>
                    <td><input type="text" id="candname" name="candname" maxlength="20" value="" style="width:90%;"></td>
                </tr>
                <tr>
                    <td nowrap="" style="width:68px;font-weight:bold;">电话:</td>
                    <td><input type="text" id="candphone" name="candphone" maxlength="20" value="" style="width:90%;"></td>
                </tr>
                <tr>
                    <td colspan="2">
                        <div class="container">
                            <div class="weui_cells_title">上传</div>
                            <div class="weui_cells weui_cells_form">
                                <div class="weui_cell">
                                    <div class="weui_cell_bd weui_cell_primary">
                                        <div class="weui_uploader">
                                            <div class="weui_uploader_hd weui_cell">
                                                <div class="weui_cell_bd weui_cell_primary">图片上传</div>
                                                <div class="weui_cell_ft js_counter">0/6</div>
                                            </div>
                                            <div class="weui_uploader_bd">
                                                <ul class="weui_uploader_files">
                                                    <!-- 预览图插入到这 -->
                                                </ul>
                                                <div class="weui_uploader_input_wrp">
                                                    <input class="weui_uploader_input js_file" type="file" accept="image/jpg,image/jpeg,image/png,image/gif" multiple="">
                                                </div>
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="weui_dialog_alert" style="display: none;">
                            <div class="weui_mask"></div>
                            <div class="weui_dialog">
                                <div class="weui_dialog_hd">
                                    <strong class="weui_dialog_title">警告</strong>
                                </div>
                                <div class="weui_dialog_bd">弹窗内容,告知当前页面信息等</div>
                                <div class="weui_dialog_ft">
                                    <a href="javascript:;" class="weui_btn_dialog primary">确定</a>
                                </div>
                            </div>
                        </div>
                        <script src="https://cdn.bootcss.com/zepto/1.1.6/zepto.min.js"></script>
                    </td>
                </tr>
            </tbody>
        </table>
    </div>

    <div class="btn_area" style="margin: 20px auto 15px auto; width: 95%; max-width: 500px; ">
        <div class="btn" id="btn_sub" style="width:100%; ">提  交</div>
    </div>
    <script>
        $("#btn_sub").click(function () {
            if ($('#candname').val().length < 1) {
                $.weui.alert({ text: '[ 姓名 ] 输入有误,请重新输入!' });
                return false;
            }

            $.ajax({
                type: "post",
                url: "_Handler/Handler.ashx",
                data: {
                    candname: $('#candname').val(),
                    candphone: $('#candphone').val()
                },
                success: function (result) {
                    if (result == "1") {
                        $.weui.alert({ title: '提示', text: '提交成功!' });
                    }
                    else if (result == "0") {
                        $.weui.alert({ text: '提交失败!' });
                    }
                }
            });
        });

        $.weui = {};
        $.weui.alert = function (options) {
            options = $.extend({ title: '警告', text: '警告内容' }, options);
            var $alert = $('.weui_dialog_alert');
            $alert.find('.weui_dialog_title').text(options.title);
            $alert.find('.weui_dialog_bd').text(options.text);
            $alert.on('touchend click', '.weui_btn_dialog', function () {
                $alert.hide();
            });
            $alert.show();
        };

        $(function () {
            // 允许上传的图片类型
            //var allowTypes = ['image/jpg', 'image/jpeg', 'image/png', 'image/gif'];
            var allowTypes = ['image/jpg', 'image/jpeg'];
            // 1024KB,也就是 1MB
            var maxSize = 5 * 1024 * 1024;
            // 图片最大宽度
            var maxWidth = 300;
            // 最大上传图片数量
            var maxCount = 6;
            $('.js_file').on('change', function (event) {
                var files = event.target.files;

                // 如果没有选中文件,直接返回
                if (files.length === 0) {
                    return;
                }

                for (var i = 0, len = files.length; i < len; i++) {
                    var file = files[i];
                    var reader = new FileReader();

                    // 如果类型不在允许的类型范围内
                    if (allowTypes.indexOf(file.type) === -1) {
                        $.weui.alert({ text: '该类型不允许上传' });
                        continue;
                    }

                    if (file.size > maxSize) {
                        $.weui.alert({ text: '图片太大,不允许上传' });
                        continue;
                    }

                    if ($('.weui_uploader_file').length >= maxCount) {
                        $.weui.alert({ text: '最多只能上传' + maxCount + '张图片' });
                        return;
                    }

                    reader.onload = function (e) {
                        var img = new Image();
                        img.onload = function () {
                            // 不要超出最大宽度
                            var w = Math.min(maxWidth, img.width);
                            // 高度按比例计算
                            var h = img.height * (w / img.width);
                            var canvas = document.createElement('canvas');
                            var ctx = canvas.getContext('2d');
                            // 设置 canvas 的宽度和高度
                            canvas.width = w;
                            canvas.height = h;
                            ctx.drawImage(img, 0, 0, w, h);
                            var base64 = canvas.toDataURL('image/jpeg');

                            // 插入到预览区
                            var $preview = $('<li class="weui_uploader_file weui_uploader_status" style="background-image:url(' + base64 + ')"><div class="weui_uploader_status_content">0%</div></li>');
                            $('.weui_uploader_files').append($preview);
                            var num = $('.weui_uploader_file').length;
                            $('.js_counter').text(num + '/' + maxCount);

                            // 然后假装在上传,可以post base64格式,也可以构造blob对象上传,也可以用微信JSSDK上传
                            var newCanvas = document.createElement('canvas');
                            var newCtx = newCanvas.getContext('2d');
                            newCanvas.width = img.width;
                            newCanvas.height = img.height;
                            newCtx.drawImage(img, 0, 0, img.width, img.height);
                            var newBase64 = newCanvas.toDataURL('image/jpeg', 1.0).toString().replace(/\+/g, "%2B");
                            
                            $.ajax({
                                type: "post",
                                url: "_Handler/ImageUpload.ashx",
                                data: {
                                    image: newBase64,
                                },
                                success: function (result) {
                                    var image = $('#hiddenImage').val();
                                    if (image == '') {
                                        $('#hiddenImage').val(result);
                                    }
                                    else {
                                        $('#hiddenImage').val(image + ';' + result);
                                    }
                                }
                            });


                            var progress = 0;
                            function uploading() {
                                $preview.find('.weui_uploader_status_content').text(++progress + '%');
                                if (progress < 100) {
                                    setTimeout(uploading, 30);
                                }
                                else {
                                    // 如果是失败,塞一个失败图标
                                    //$preview.find('.weui_uploader_status_content').html('<i class="weui_icon_warn"></i>');
                                    $preview.removeClass('weui_uploader_status').find('.weui_uploader_status_content').remove();
                                }
                            }
                            setTimeout(uploading, 30);
                        };

                        img.src = e.target.result;
                    };
                    reader.readAsDataURL(file);
                }
            });
        });
    </script>
    <div class="mpa-sc image-gatherer mpa-rootsc" data-z="100" style="display: block;" id="mpa-rootsc-image-gatherer"></div><div class="mpa-sc notifier mpa-rootsc" data-z="110" style="display: block;" id="mpa-rootsc-notifier"></div>
</body>
</html>

 

注意点:

var newBase64 = newCanvas.toDataURL('image/jpeg', 1.0).toString().replace(/\+/g, "%2B");
这里将图片转化为base64,然后将base64中的+号替换为'%2B'

 

图片上传处理:

string image = context.Request["image"].ToString().Replace("data:image/jpeg;base64,", "");
string result = Base64StringToImage(image);

 //base64编码的文本 转为    图片  
    private string Base64StringToImage(string baseImages)
    {
        try
        {
            string dummyData = baseImages.Trim().Replace("%2B", "+").Replace("%", "").Replace(",", "");
            if (dummyData.Length % 4 > 0)
            {
                dummyData = dummyData.PadRight(dummyData.Length + 4 - dummyData.Length % 4, '=');
            }
            byte[] arr = Convert.FromBase64String(dummyData);
            MemoryStream ms = new MemoryStream(arr);
            Bitmap bmp = new Bitmap(ms);
            string path = "/files/" + DateTime.Now.ToString("yyyy-MM-dd") + "/";
            if (!Directory.Exists(HttpContext.Current.Server.MapPath(path)))
            {
                Directory.CreateDirectory(HttpContext.Current.Server.MapPath(path));
            }
            string fileName = Guid.NewGuid().ToString() + ".jpg";
            bmp.Save(HttpContext.Current.Server.MapPath(path) + fileName, System.Drawing.Imaging.ImageFormat.Jpeg);
            ms.Close();
            return path + fileName;
        }
        catch (Exception ex)
        {
            throw ex;
        }
    }

 

参考:

使用weui uploader 上传

ajax传数据和图片(base64格式)