实验三、 基于Hadoop的Web版的云盘(必须基于实验一验证通过的环境) 一、实验目的 二、实验原理 三、实验环境 四、实验内容 1.打开IDEA,导入项目“clouddisk”。 2.修改配置 3.修改用户代码观察网盘效果 4.右键运行 5.开发,实现上传、下载 五、代码附录
时间: 2024-05-27 10:14:14 浏览: 182
抱歉,作为AI语言模型,我无法提供完整的代码,因为这需要根据具体的实验环境和需求进行编写和调试。以下是一些可能用到的代码片段供参考:
1. Hadoop配置
在项目的conf目录下,创建一个名为hadoop.properties的文件,添加以下内容:
fs.defaultFS=hdfs://localhost:9000
mapreduce.framework.name=yarn
yarn.resourcemanager.address=localhost:8032
2. 用户代码
用户代码可以在项目的src/main/java/com/clouddisk/web/controller目录下的Controller类中编写。
例如,以下是一个实现上传文件的方法:
@RequestMapping(value = "/uploadFile", method = RequestMethod.POST)
@ResponseBody
public String uploadFile(HttpServletRequest request, @RequestParam("file") MultipartFile file) {
String fileName = file.getOriginalFilename();
try {
FileSystem fs = FileSystem.get(new Configuration());
Path dst = new Path("/user/hadoop/" + fileName);
FSDataOutputStream outputStream = fs.create(dst);
outputStream.write(file.getBytes());
outputStream.close();
return "success";
} catch (IOException e) {
e.printStackTrace();
return "fail";
}
}
该方法通过使用Hadoop API将上传的文件保存到HDFS中。
3. 页面代码
页面代码可以在项目的src/main/resources/static目录下的HTML文件中编写。
例如,以下是一个展示文件列表的HTML代码:
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Size</th>
<th>Actions</th>
</tr>
</thead>
<tbody>
<tr th:each="file : ${files}">
<td th:text="${file.name}"></td>
<td th:text="${file.type}"></td>
<td th:text="${file.size}"></td>
<td>
<a th:href="@{/downloadFile(file=${file.name})}">Download</a>
</td>
</tr>
</tbody>
</table>
该代码使用Thymeleaf模板引擎动态生成文件列表,并提供下载文件的链接。
阅读全文