在上周我们为大家介绍了“ThinkPHP5+ajax预览并上传单张图片的实现方法及代码”的内容,今天我们继续为大家带来升级版:ThinkPHP5+ajax实现预览并上传多张图片的方法及代码:
首先们看下界面:
其次是html代码:
<html>
<head>
<meta charset="UTF-8">
<title>文件上传</title>
<style type="text/css">
#front {
width: 120px;
height: 120px;
background-color: #8A6DE9;
}
#frontage {
width: 120px;
height: 120px;
background-color: #8A6DE9;
}
#banking {
width: 120px;
height: 120px;
background-color: #8A6DE9;
}
#house {
width: 120px;
height: 120px;
background-color: #8A6DE9;
}
</style>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
</head>
<body>
<form id="uploadForm">
<!-- 1 -->
<p>身份证正面:<input type="file" name="drawing" id="drawing" onchange="identity(this)" autocomplete="off" /></p>
<input type="text" name="" id="fronts" value="" />
<div id="front"></div>
<!-- 1 -->
<!-- 2 -->
<p>身份证反面:<input type="file" name="reverse" id="reverse" onchange="card(this)" autocomplete="off" /></p>
<input type="text" name="" id="frontages" value="" />
<div id="frontage"></div>
<!-- 2 -->
<!-- 3 -->
<p>银行卡正面: <input type="file" name="transaction" id="transaction" onchange="obverse(this)" autocomplete="off" /></p>
<input type="text" name="" id="bankings" value="" />
<div id="banking"></div>
<!-- 3 -->
<!-- 4 -->
<p>银行卡反面: <input type="file" name="redlining" id="redlining" onchange="versa(this)" autocomplete="off" /></p>
<input type="text" name="" id="houses" value="" />
<div id="house"></div>
<!-- 4 -->
</form>
</body>
</html>
<!-- 身份证正面 -->
<script type="text/javascript">
function identity() {
var formData = new FormData();
formData.append("drawing", $('#drawing')[0].files[0]);
// console.log(formData);
$.ajax({
url: "http://tp5-shopxo.likeball.top/index.php?s=/api/Mi/measurement",
type: 'POST',
data: formData,
dataType: 'JSON',
cache: false,
processData: false,
contentType: false,
success: function(data) {
console.log(data);
if (data['whether'] == true) {
var result = '';
var result1 = '';
result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
$('#front').html(result);
$('#fronts').val(result1);
}
},
error: function(data) {
console.log("错误");
}
});
}
</script>
<!-- 身份证反面 -->
<script type="text/javascript">
function card() {
var formData = new FormData();
formData.append("reverse", $('#reverse')[0].files[0]);
// console.log(formData);
$.ajax({
url: "http://tp5-shopxo.likeball.top/index.php?s=/api/Mi/measurement",
type: 'POST',
data: formData,
dataType: 'JSON',
cache: false,
processData: false,
contentType: false,
success: function(data) {
console.log(data);
if (data['whether'] == true) {
var result = '';
var result1 = '';
result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
$('#frontage').html(result);
$('#frontages').val(result1);
}
},
error: function(data) {
console.log("错误");
}
});
}
</script>
<!-- 银行卡正面 -->
<script type="text/javascript">
function obverse() {
var formData = new FormData();
formData.append("transaction", $('#transaction')[0].files[0]);
// console.log(formData);
$.ajax({
url: "http://tp5-shopxo.likeball.top/index.php?s=/api/Mi/measurement",
type: 'POST',
data: formData,
dataType: 'JSON',
cache: false,
processData: false,
contentType: false,
success: function(data) {
console.log(data);
if (data['whether'] == true) {
var result = '';
var result1 = '';
result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
$('#banking').html(result);
$('#bankings').val(result1);
}
},
error: function(data) {
console.log("错误");
}
});
}
</script>
<!-- 银行卡反面 -->
<script type="text/javascript">
function versa() {
var formData = new FormData();
formData.append("redlining", $('#redlining')[0].files[0]);
// console.log(formData);
$.ajax({
url: "http://tp5-shopxo.likeball.top/index.php?s=/api/Mi/measurement",
type: 'POST',
data: formData,
dataType: 'JSON',
cache: false,
processData: false,
contentType: false,
success: function(data) {
console.log(data);
if (data['whether'] == true) {
var result = '';
var result1 = '';
result += '<img src="' + 'http://tp5-shopxo.likeball.top/' + data['site'] + '" width="100">';
result1 += 'http://tp5-shopxo.likeball.top/' + data['site'];
$('#house').html(result);
$('#houses').val(result1);
}
},
error: function(data) {
console.log("错误");
}
});
}
</script>
接着是控制器代码:
public function measurement()
{
$response = array();
//这是身份证正面
if ( isset( $_FILES['drawing'] ) && $_FILES['drawing']['error'] == 0 ) {
$drawing = request()->file('drawing');
$picture = $drawing->validate( ['ext'=>'jpg,png,gif'] )->move( ROOT_PATH . 'static' . DS . 'upload/mi/img' );
}
if ( isset( $picture ) ) {
$filePaths = '/static' . DS . 'upload/mi/img/'. $picture->getSaveName();
$response['whether'] = true;
$response['site'] = $filePaths;
echo json_encode($response);
}
// 正面结束
// 这是反面
if ( isset( $_FILES['reverse'] ) && $_FILES['reverse']['error'] == 0 ) {
$reverse = request()->file('reverse');
$reverse = $reverse->validate( ['ext'=>'jpg,png,gif'] )->move( ROOT_PATH . 'static' . DS . 'upload/mi/img' );
}
if ( isset( $reverse ) ) {
$contrary = '/static' . DS . 'upload/mi/img/'. $reverse->getSaveName();
$response['whether'] = true;
$response['site'] = $contrary;
echo json_encode($response);
}
//银行卡正面
if ( isset( $_FILES['transaction'] ) && $_FILES['transaction']['error'] == 0 ) {
$transaction = request()->file('transaction');
$transaction = $transaction->validate( ['ext'=>'jpg,png,gif'] )->move( ROOT_PATH . 'static' . DS . 'upload/mi/img' );
}
if ( isset( $transaction ) ) {
$stuck = '/static' . DS . 'upload/mi/img/'. $transaction->getSaveName();
$response['whether'] = true;
$response['site'] = $stuck;
echo json_encode($response);
}
//银行卡反面
if ( isset( $_FILES['redlining'] ) && $_FILES['redlining']['error'] == 0 ) {
$redlining = request()->file('redlining');
$redlining = $redlining->validate( ['ext'=>'jpg,png,gif'] )->move( ROOT_PATH . 'static' . DS . 'upload/mi/img' );
}
if ( isset( $redlining ) ) {
$other = '/static' . DS . 'upload/mi/img/'. $redlining->getSaveName();
$response['whether'] = true;
$response['site'] = $other;
echo json_encode($response);
}
}
好了,这样就可以实现ThinkPHP5+ajax实现预览并上传多张图片的全部信息了,希望对你的网站建设有所帮助。