前言在瀏覽器使用hml中的ipu框我們可以實現(xiàn)文件的上傳,表單元素選用&l;ipuype=&quo;file&quo;&g;控件,fom表單需要設(shè)置ecype=&quo;mulipa/fom-daa&quo;屬性。比如:&l;body&g;&l;fomacio=&quo;UploadFile.php&quo;m......
以下是【金聰采編】分享的內(nèi)容全文:
以下是【金聰采編】分享的內(nèi)容全文:
web 開發(fā)過程中經(jīng)常會需要進行參數(shù)驗證,laravel 中我們常用 validator 或者 request 這兩種方法來進行驗證,但是這兩種驗證都不是很方便進行自定義提示信息,自定義驗證規(guī)則,所以下面來介紹一種很方便的用法:
新建抽象類
<?phpnamespace App/Http/Validators;use Validator;abstract class AbstractValidator{ /** * Validator * * @var /Illuminate/Validation/Factory */ protected $validator; /** * Validation data key => value array * * @var array */ protected $data = array(); /** * Validation errors * * @var array */ protected $errors = array(); /** * Validation rules * * @var array */ protected $rules = array(); /** * Validation messages * * @var array */ protected $messages = array(); /** * Validation codes * * @var array */ protected $codes = array(); public function __construct(array $data) { $this->data = $data; $this->before(); $this->validator = Validator::make($this->data, $this->rules, $this->messages); $this->after(); } /** * Set data to validate * * @return validator */ public function getValidator() { return $this->validator; } /** * Set data to validate * * @return $this */ public function with(array $data) { $this->data = $data; $this->before(); $this->validator = $this->validator->make($this->data, $this->rules, $this->messages); $this->after(); return $this; } /** * Validation passes or fails * * @return boolean */ public function passes() { if ($this->validator->fails()) { $this->errors = $this->validator->messages(); return false; } return true; } /** * Return errors, if any * * @return array */ public function errors() { return $this->errors; } /** * Return errors codes, if any * * @return array */ public function getCodes() { return $this->codes; } /** * getRules * * @return array */ public function getRules() { return $this->rules; } /** * getData * * @return array */ public function getData() { return $this->data; } /** * getErrors * * @return array */ public function getErrors() { return $this->errors; } /** * getMessages * * @return array */ public function getMessages() { return $this->messages; } /** * setRule * * @param string $key * @param string $value * * @return $this */ public function setRule($key, $value) { $this->rules[$key] = $value; return $this; } /** * emptyRules * * @return $this */ public function emptyRules() { $this->rules = array(); return $this; } /** * sometimes * * @param string $attribute * @param string|array $rules * @param callable $callback * * @return $this */ public function sometimes($attribute, $rules, callable $callback) { $this->validator->sometimes($attribute, $rules, $callback); return $this; } /** * resolver * * @param Closure $resolver * * @return $this */ public function resolver(Closure $resolver) { Validator::resolver($resolver); return $this; } /** * replacer * * @param Closure $resolver * * @return $this */ public function replacer($replace, Closure $resolver) { Validator::replacer($replace, $resolver); return $this; } /** * extendImplicit * * @param Closure $resolver * * @return $this */ public function extendImplicit($extendImplicit, Closure $resolver) { Validator::extendImplicit($extendImplicit, $resolver); return $this; } /** * extend * * @param string $rule * @param /Closure|string $extension * @param string $message * * @return $this */ public function extend($rule, $extension, $message = null) { Validator::extend($rule, $extension, $message); return $this; } /** * before (extend(),resolver()) * * @return $this */ public function before() { } /** * after(sometimes()) * * @return $this */ public function after() { }}新建中間件
<?phpnamespace App/Http/Middleware;use Closure;use /Illuminate/Http/Request;class ValidateAdminMiddleware{ /** * This namespace is applied to the controller routes in your routes file. * * In addition, it is set as the URL generator's root namespace. * * @var string */ protected $namespace = 'App/Http/Validators'; /** * Handle an incoming request. * * @param /Illuminate/Http/Request $request * @param /Closure $next * * @return mixed */ public function handle(Request $request, Closure $next, $validator = null) { if ($request->isMethod('POST')) { $type = $request->segment(1); if ($validator) { $validator = $this->namespace . '//' . studly_case($type) . '//' . studly_case($validator) . 'Validator'; $validator = new $validator($request->all()); if (!$validator->passes()) { if ($request->isAjax()) { return $validator->errors()->first(); } else { return redirect()->back() ->withErrors($validator->getValidator()) ->withInput(); } } } } return $next($request); }}新建 TestTestValidator
<?phpnamespace App/Http/Validators/Admin;use App/Http/Validators/AbstractValidator;class TestValidator extends AbstractValidator{ /** * Validation rules * * @var Array */ protected $rules = array( 'name' => ['required', 'test', 'min:1'], ); /** * Validation messages * * @var Array */ protected $messages = array( 'name.required' => '必填', 'name.min' => '最少1個字符', 'name.test' => '測試', ); /** * 自定義驗證規(guī)則或者擴展Validator類 */ public function before() { $this->extend('test', function ($attribute, $value, $parameters) { return bool; }); }}路由中如何使用
Route::post('/', ['middleware' => ['valiAdmin:Test'], 'uses' => 'IndexController@test']);具體使用可以自行配置~
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持金聰精品。
金聰線報提示:[ php使用curl模擬瀏覽器表單上傳文件或者圖片的方法 ] 僅為會員分享,分享目的如下:
1.軟件源碼推廣展示:目的展示軟件相關(guān)功能,接收技術(shù)學(xué)習(xí)者測試、測評;
2.教程課程信息展示:展示課程信息,傳授課程各階段內(nèi)容;
3.設(shè)計素材圖片展示:展示素材設(shè)計理念、思維方式、傳播設(shè)計理念;
4.福利優(yōu)惠信息展示:分享各類最新的福利信息,各種優(yōu)惠信息展示;
以上分享目的僅供學(xué)習(xí)、參考使用,請勿用于其他用途,如果想商業(yè)使用或者代理,請自行聯(lián)系版權(quán)方獲取授權(quán)。任何未獲取授權(quán)的商業(yè)使用與本站無關(guān),請自行承擔(dān)相應(yīng)責(zé)任。
本站不存儲任何資源文件,敬請周知!
本網(wǎng)站采用 BY-NC-SA 協(xié)議進行授權(quán) 轉(zhuǎn)載請注明原文鏈接:php使用curl模擬瀏覽器表單上傳文件或者圖片的方法
1.軟件源碼推廣展示:目的展示軟件相關(guān)功能,接收技術(shù)學(xué)習(xí)者測試、測評;
2.教程課程信息展示:展示課程信息,傳授課程各階段內(nèi)容;
3.設(shè)計素材圖片展示:展示素材設(shè)計理念、思維方式、傳播設(shè)計理念;
4.福利優(yōu)惠信息展示:分享各類最新的福利信息,各種優(yōu)惠信息展示;
以上分享目的僅供學(xué)習(xí)、參考使用,請勿用于其他用途,如果想商業(yè)使用或者代理,請自行聯(lián)系版權(quán)方獲取授權(quán)。任何未獲取授權(quán)的商業(yè)使用與本站無關(guān),請自行承擔(dān)相應(yīng)責(zé)任。
本站不存儲任何資源文件,敬請周知!
此資源僅供個人學(xué)習(xí)、研究使用,禁止非法轉(zhuǎn)播或商業(yè)用途,請在獲取后24小時內(nèi)刪除,如果你覺得滿意,請尋求購買正版或獲取授權(quán)!
如果您認(rèn)為本頁信息內(nèi)容侵犯了您的相關(guān)權(quán)益(包含但不限于:著作權(quán)、首發(fā)權(quán)、隱私權(quán)等權(quán)利),或者您認(rèn)為自己是此信息的權(quán)利人但是此信息不是自己發(fā)布的,可以直接版權(quán)舉報投訴,我們會根據(jù)網(wǎng)站注冊協(xié)議、資源分享協(xié)議等協(xié)議處理,以保護您的合法權(quán)益。
免責(zé)申明:本站僅提供學(xué)習(xí)的平臺,所有資料均來自于網(wǎng)絡(luò)分享線索,版權(quán)歸原創(chuàng)者所有!本站不提供任何保證,并不承擔(dān)任何法律責(zé)任,如果對您的版權(quán)或者利益造成損害,請?zhí)峁┫鄳?yīng)的資質(zhì)證明,我們將于3個工作日內(nèi)予以處理。版權(quán)申訴相關(guān)說明如果您認(rèn)為本頁信息內(nèi)容侵犯了您的相關(guān)權(quán)益(包含但不限于:著作權(quán)、首發(fā)權(quán)、隱私權(quán)等權(quán)利),或者您認(rèn)為自己是此信息的權(quán)利人但是此信息不是自己發(fā)布的,可以直接版權(quán)舉報投訴,我們會根據(jù)網(wǎng)站注冊協(xié)議、資源分享協(xié)議等協(xié)議處理,以保護您的合法權(quán)益。
本網(wǎng)站采用 BY-NC-SA 協(xié)議進行授權(quán) 轉(zhuǎn)載請注明原文鏈接:php使用curl模擬瀏覽器表單上傳文件或者圖片的方法

侵權(quán)舉報/版權(quán)申訴



