写在前面:这里提供一种解决问题思路,跟什么语言无关,可具体问题具体分析;
这里用到的是PHP,框架是Laravel.
/**
* 1、前端访问页面的时候会请求路径,然后调用路由,请求PHP文件,获取数据之后返回给前端
* 这里使用访问页面的时间作为唯一标识,生成二维码图片
* 二维码图片里面信息包括:
*
* 扫一扫上传图片 - 后端 - 代码
*/
//当前时间 $rs['current']=time(); //二维码保存地址 $PNG_WEB_DIR = 'uploads/qr/'; //加载二维码生成类 include "phpqrcode/qrlib.php"; //设置二维码容错等级 $errorCorrectionLevel = 'H'; //生成图片的大小 $matrixPointSize = 4; //扫描二维码访问的地址 - 带上当前访问时间作为唯一标识 $data='http://'.$_SERVER['HTTP_HOST'].'/qr-upload?time='.$rs['current']; //生成二维码文件 // uploads/qr/sfwer9234-98252-359-235.png $filename = $PNG_WEB_DIR.md5($data.'|'.$errorCorrectionLevel.'|'.$matrixPointSize).'.png'; // php 生成二维码类: // 参数介绍: // 第1个参数$text:二维码包含的内容,可以是链接、文字、json字符串等等; // 第2个参数$outfile:默认为false,不生成文件,只将二维码图片返回输出;否则需要给出存放生成二维码图片的文件名及路径; // 第3个参数$level:默认为L,这个参数可传递的值分别是L(QR_ECLEVEL_L,7%)、M(QR_ECLEVEL_M,15%)、Q(QR_ECLEVEL_Q,25%)、H(QR_ECLEVEL_H,30%)这个参数控制二维码容错率,不同的参数表示二维码可被覆盖的区域百分比,也就是被覆盖的区域还能识别; // 第4个参数$size:控制生成图片的大小,默认为4; // 第5个参数$margin:控制生成二维码的空白区域大小; // 第6个参数$saveandprint:保存二维码图片并显示出来,$outfile必须传递图片路径; QRcode::png($data, $filename, $errorCorrectionLevel, $matrixPointSize, 2); //二维码输出路径,获取二维码给前端进行展示 $rs['qr_img']=HTML::image($PNG_WEB_DIR.basename($filename));
/**
* 2、拿到后端返回的数据进行输出绑定
* 前端代码
*/
<div role="tabpanel" class="tab-pane active text-center qr-img" id="p1">
<p>
{{$qr_img}} //展示二维码 - 一张图片
<span>扫描左侧二维码即可上传照片</span>
</p>
//当前访问地址的时间,由后台返回 - 后续用来查图片进行展示
<span class="btn btn-info ae-uploaded" data-biaoshi="{{$current or ''}}">我已上传图片</span>
</div>
/**
* 3、手机扫码进行上传操作
* 扫码之后跳转到H5页面,进行上传图片
* 扫码:
* 后端代码:
*/
$rs['time']=Input::get('time'); //获取前端传过来的时间进行过期判断,如果过期返回错误提示
/**
* 4、前端绑定后端传过来的数据,进行展示
* 在这里进行上传图片操作,上传之后返回图片地址;
* 前端代码:
*/
{{Form::open(['url'=>URL::current(),'enctype'=>'multipart/form-data','id'=>'cdc'])}}
<div class="container">
<div class="row text-center">
<div class="col-md-12">
<div id="queue" class="ht30" style="display:none;"></div>
</div>
<div class="col-md-12 mt10">
<div class="db bgwh ht200 p-plus" id="i1">身份证正面</div>
<input type="file" id="s1" class="btn btn-primary btn-lg mt10 whp100">
<span class="msg-box" for="h1"></span>
</div>
<div class="col-md-12 mt10">
<div class="db bgwh ht200 p-plus" id="i2">身份证背面</div>
<input type="file" id="s2" class="btn btn-primary btn-lg mt10 whp100">
<span class="msg-box" for="h2"></span>
</div>
<div class="col-md-12 mt10">
<div class="db bgwh ht200 p-plus" id="i3">手持正面</div>
<input type="file" id="s3" class="btn btn-primary btn-lg mt10 whp100">
<span class="msg-box" for="h3"></span>
</div>
{{Form::hidden('biaoshi',$time)}}
<input type="hidden" name="h1" data-rule="required;">
<input type="hidden" name="h2" data-rule="required;">
<input type="hidden" name="h3" data-rule="required;">
<div class="col-md-12 mt20 ">
<button class="btn btn-danger btn-lg whp100">上 传</button>
</div>
</div>
</div>
{{Form::close()}}
$("#s1").UploadImg({
url : "/qr-upload.php",
width : "640",
quality : "0.7", //压缩率,默认值为0.7
mixsize : "10000000",
before : function(blob){
$("#i1").html(hh);
},
error : function(d){
$("#i1").html('上传失败请重新上传');
},
success : function(d){
$("#i1").html('<img class="lazyload" src="" data-original="/'+d+'" class="img-responsive bim">');
$("input[name='h1']").val("/"+d);
}
});
//剩余两个省略........
/**
* 5、上传之后进行保存到数据库:
* 数据库字段:pic1,pic2,pic3,unique-id(浏览页面的时间戳,进行唯一标识处理)
* 这里保存到数据库的是上一步上传之后返回的图片地址:
* 保存成功之后跳转到上传成功页面:
* 代码如下:
*/
public function qrpost(){
$input=Input::all();
$arr['pic1']=$input['h1'];
$arr['pic2']=$input['h2'];
$arr['pic3']=$input['h3'];
$arr['biaoshi']=$input['biaoshi'];
Lice::create($arr);
return Redirect::to('/qrok');
}
/**
* 6、保存到数据库之后(上传成功之后),PC浏览器点击按钮“我已上传图片”,AJAX拿着上面第二步前端绑定的时间值,去查出来刚上传的图片:
* 前端代码:
*/
$(".ae-uploaded").click(function () {
var biaoshi = $(this).attr("data-biaoshi"); //这里获取的"attr"就是时间唯一标识
var str;
$.ajax({
type: "post",
dataType: "json",
data: {"biaoshi": biaoshi},
url: "/qr-fetch",
success: function (d) {
if(d.flag) {
str = '<img style="height:127px" class="img-responsive ml10" class="lazyload" src="" data-original="' + d.file.pic1 + '">';
str += '<img style="height:127px" class="img-responsive ml10" class="lazyload" src="" data-original="' + d.file.pic2 + '">';
str += '<img style="height:127px" class="img-responsive ml10" class="lazyload" src="" data-original="' + d.file.pic3 + '">';
$(".qr-img").html(str);
$("input[name='package[pic1]']").val(d.file.pic1);
$("input[name='package[pic2]']").val(d.file.pic2);
$("input[name='package[pic3]']").val(d.file.pic3);
$(".uploaded").hide();
}else {
alert("上传失败,请重新在手机上传");
}
}
});
});
//后端代码
public function qrfetch(){
$biaoshi=Input::get('biaoshi');
$info=Lice::where('biaoshi',$biaoshi)->select('pic1','pic2','pic3')->first();
if($info){
return Response::json(['flag'=>true,'file'=>$info]);
}else{
return Response::json(['flag'=>false]);
}
}
/**
* 7、PC得到上传之后的图片地址,进行展示,然后可进行接下来的操作,把图片和当前用户绑定起来即可,具体要看业务怎么实现了
* 这里只是说明一下上传之后展示和当前PC登录的用户如何绑定,自己可去实现
*/
共同学习,写下你的评论
评论加载中...
作者其他优质文章