路线
Route::get('/mediafile', 'MediaController@index');
的MediaController
public function store(Request $request)
{
$image = $request->file('UserFile');
if($request->hasFile('UserFile')) {
$filename = $image->getClientOriginalName();
Image::make($image)->resize(300, 300)->save(public_path('media/' . $filename));
$media = new Media();
$media->Description = $request->Description ? $request->Description : '';
$media->MediaPath = $filename;
$media->MediaName = $filename;
$media->save();
}
return response()->json($media);
}
查看
<div class="form-group image">
<div class="col-xs-12 col-sm-12 col-md-12">
<label>Gambar</label><input type="file" name="UserFile" id="userfile" style="display: inline">
<label style="margin-left: 25px">atau</label>
<a href="http://192.168.1.12/melody4/media/select.html" class="pilihmedia btn btn-default">Pilih dari media</a>
<input type="hidden" id="MediaID" name="CategoryMediaID" value="" />
<br /><br />
<span class="uploadstatus"></span>
<div class="success infomedia infomedia alert alert-success" style="display: none">
</div>
</div>
的Ajax
$('#userfile').change(function(){
$(this).attr('disable',true);
$('.uploadstatus').html('Sedang mengupload file <img src="{{ asset('vendor/img/loading.gif') }}" alt="ajaxloading" />');
$(this).parent().ajaxSubmit({
url: "<?php echo url('/mediafile') ?>",
dataType: 'json',
type: "POST",
success : function(data){
$(this).attr('disable',false);
$('.uploadstatus').empty();
},
error : function(data){
}
});
});
我在发布图片时使用AJAX时出现错误“405 Method Not Allowed”,我已经研究并遵循Stack Overflow中的所有答案,但我仍然无法解决它。
请帮我解决。
答案 0 :(得分:1)
可能是csrf令牌中的问题 在html中添加此行
<meta name="_token" content="{{ csrf_token() }}"/>
和ajax
$.ajaxSetup({
headers: { 'X-CSRF-Token' : $('meta[name=_token]').attr('content') }
});
需要在ajax调用中发布图像
答案 1 :(得分:0)
将Route::get
更改为Route::post
以处理POST请求。
如果您需要同时支持GET和POST:请使用Route::match
或Route::any
。
在此处阅读有关Laravel路由器的更多信息:https://laravel.com/docs/5.5/routing