Cet article parle principalement de la fonction de téléchargement de fichiers de angularjs Savez-vous comment télécharger des fichiers dans Angularjs ? Angularjs est la page front-end. Savez-vous ce qui est utilisé dans le backend ? Lisons cet article maintenant
Utilisez
AngularJS
pour télécharger des fichiers
Angular
SpringBoot/SpirngMVC
<p> <input id="fileUpload" type="file" /> <button ng-click="uploadFile()">上传</button></p>
$scope.upload = function(){ var form = new FormData(); var file = document.getElementById("fileUpload").files[0]; form.append('file', file); $http({ method: 'POST', url: '/upload', data: form, headers: {'Content-Type': undefined}, transformRequest: angular.identity }).success(function (data) { console.log('upload success'); }).error(function (data) { console.log('upload fail'); }) }
Remarque :
- Le
par défaut d'AngularJS est
'Content-Type'
En définissantapplication/json
, le navigateur ne nous aidera pas seulement à définir'Content-Type': undefined
surContent-Type
, mais remplissez également lemultipart/form-data
actuelboundary
- Si défini manuellement sur :
, une exception sera levée en arrière-plan :
<. 🎜>'Content-Type': multipart/form-data
the request was rejected because no multipart boundary was found
- est une chaîne de caractères générée aléatoirement, utilisée pour séparer le début et la fin du texte
En définissant
boundary
- ,
sérialisera notre
transformRequest: angular.identity
, ou vous ne pouvez pas ajouteranjularjs transformRequest function
formdata object
@RequestMapping("/upload") public void uploadFile(@RequestParam(value = "file" , required = true) MultipartFile file) { //deal with file }
Le fichier doit passer l'annotation @RequestParam pour être obtenu, et la valeur doit être spécifiée pour obtenir
<p> <input id="fileUpload" type="file" /> <button ng-click="ok()">上传</button><br> <input ng-model="user.username" /> <input ng-model="user.password" /> </p>
$scope.ok = function () { var form = new FormData(); var file = document.getElementById("fileUpload").files[0]; var user =JSON.stringify($scope.user); form.append('file', file); form.append('user',user); $http({ method: 'POST', url: '/addUser', data: form, headers: {'Content-Type': undefined}, transformRequest: angular.identity }).success(function (data) { console.log('operation success'); }).error(function (data) { console.log('operation fail'); }) };
Remarque
Vous devez convertir l'objet en chaîne avant de l'ajouter au formulaire, sinon il sera directement converti en chaîne [Objet, objet]
@RequestMapping("/upload") public Map<String, Object> upload(@RequestParam(value = "file") MultipartFile file, @RequestParam(value = "user", required = true) String user) { try (FileInputStream in = (FileInputStream) headImg.getInputStream(); FileOutputStream out = new FileOutputStream("filePathAndName")) { //将Json对象解析为UserModel对象 ObjectMapper objectMapper = new ObjectMapper(); UserModel userModel = objectMapper.readValue(user, UserModel.class); //保存文件到filePathAndName int hasRead = 0; byte[] bytes = new byte[1024]; while ((hasRead = in.read(bytes)) > 0) { out.write(bytes, 0, hasRead); } } catch (IOException e) { e.printStackTrace(); } }
pour télécharger des fichiersCet article se termine ici (si vous voulez en voir plus, rendez-vous sur PHP (site Web chinois
- Manuel d'utilisation AngularJS
)) , si vous avez des questions, vous pouvez laisser un message ci-dessous.
ObjectMapper
com.fasterxml.jackson.databind.ObjectMapper
AngularJS
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!