jsp - JavaEE如何将文件上传到glassfish4服务器?
问题描述
我正在使用 eclipse 做一些 java web 应用程序,并将 .war 文件托管在其他 PC 的 glassfish4 服务器上。
我写了一个jsp页面,jsp页面需要用户输入各种信息,浏览任何一种文件(比如txt,或者图片文件),然后上传到glassfish4本地服务器。
我在谷歌上做了很多搜索,但我找不到任何解决方案,你们能帮我解决这些问题吗?
这是我的 JSP 页面代码:
<form action="uploadFile" method="POST" enctype="multipart/form-data">
<div class="card-body">
<h5 class="card-title">Equipment Request</h5>
<div class="form-group row">
<label for="reqEmail" class="col-sm-2 text-right control-label col-form-label">Requestor</label>
<div class="col-sm-4">
<input type="text" class="form-control" id="reqEmail" name="reqEmail" disabled value="reggiezhiyi.lim@motorolasolutions.com">
</div>
<label for="ID" class="col-sm-1 text-right control-label col-form-label">Request ID</label>
<div class="col-sm-4">
<input type="text" class="form-control" id="ID" name="ID" disabled value="0000001">
</div>
</div>
<div class="form-group row">
<label for="projectName" class="col-sm-2 text-right control-label col-form-label">Project</label>
<div class="col-sm-4">
<input type="text" class="form-control" id="projectName" name="projectName" maxlength="50" placeholder="Enter the Project Name..">
</div>
</div>
<div class="form-group row">
<label for="contactNum" class="col-sm-2 text-right control-label col-form-label">Contact No.</label>
<div class="col-sm-3">
<input type="number" class="form-control" id="contactNum" name="contactNum" maxlength="50" placeholder="Enter the Phone Number">
</div>
</div>
<div class="form-group row">
<label for="manID" class="col-sm-2 text-right control-label col-form-label">Manager Core ID</label>
<div class="col-sm-4">
<input type="text" class="form-control" id="manID" name="manID" maxlength="50" placeholder="Enter the Manager Core ID">
</div>
</div>
<div class="form-group row">
<label for="from" class="col-sm-2 text-right control-label col-form-label">Loan Date From</label>
<div class="col-sm-4 input-group">
<input type="text" class="form-control" id="datepicker-autoclose" placeholder="mm/dd/yyyy">
<div class="input-group-append">
<span class="input-group-text"><i class="fa fa-calendar"></i></span>
</div>
</div>
<label for="to" class="col-sm-1 text-right control-label col-form-label">To</label>
<div class="col-sm-4 input-group">
<input type="text" class="form-control" id="datepicker-autoclose1" placeholder="mm/dd/yyyy">
<div class="input-group-append">
<span class="input-group-text"><i class="fa fa-calendar"></i></span>
</div>
</div>
</div>
<div class="form-group row">
<label for="reason" class="col-sm-2 text-right control-label col-form-label">Reason for Loan</label>
<div class="col-sm-6">
<textarea rows="3" class="form-control" id="reason" name="reason"></textarea>
</div>
</div>
<div class="form-group row">
<label for="attach" class="col-sm-2 text-right control-label col-form-label">Attachment</label>
<div class="col-sm-6">
<div class="custom-file">
<label class="custom-file-label" for="validatedCustomFile" placeholder="Choose File.."></label>
<input type="file" class="custom-file-input" id="validatedCustomFile" name="validatedCustomFile" required>
</div>
</div>
</div>
<div class="form-group row">
<label for="comment" class="col-sm-2 text-right control-label col-form-label">Equiment Configuration</label>
<div class="col-sm-9">
<textarea rows="5" class="form-control" id="comment" name="comment"></textarea>
</div>
</div>
<div class="form-group row">
<label for="shipping" class="col-sm-2 text-right control-label col-form-label">Shipping Address</label>
<div class="col-sm-9">
<textarea rows="3" class="form-control" id="shipping" name="shipping"></textarea>
</div>
</div>
<div class="form-group row">
<label for="return" class="col-sm-2 text-right control-label col-form-label">Return Address</label>
<div class="col-sm-9">
<textarea rows="3" class="form-control" id="return" name="return" disabled>Motorola Solutions Penang</textarea>
</div>
</div>
<div class="form-group row">
<label for="inven" class="col-sm-2 text-right control-label col-form-label">Inventory List</label>
<div class="col-sm-8"></div>
<div class="col-sm-2">
<button type="button" class="btn btn-primary" onclick="addTable()">Add</button>
<button type="button" class="btn btn-danger" onclick="deleteTable()">Delete</button>
</div>
<br>
<!-- <div class="col-sm-2"></div> -->
<div class="col-sm-12">
<table class="table" id="tableList">
<thead>
<tr>
<th scope="col">Category</th>
<th scope="col">Item</th>
<th scope="col">Sales Model No.</th>
<th scope="col">Asset Tag</th>
<th scope="col">Serial No.</th>
<th scope="col">Quantity</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
<div class="border-top">
<div class="card-body">
<button type="submit" class="btn btn-primary">Submit</button>
<button type="button" id="test" class="btn btn-primary">Test</button>
<button type="reset" class="btn btn-info">Reset</button>
</div>
</div>
</form>
该操作直接指向一个uploadFile.java,我不知道如何将文件上传到数据库中。
我有几个关于上传到数据库的问题:
1. 将文件直接上传到数据库
2. 将文件上传到 glassfish4 本地服务器,并将路径保存到数据库
上传到数据库后,我想检索文件,让其他用户下载。
我想知道哪个1更容易实现?哪个1是更正确的方法。
解决方案
因此,数据库中的文件需要保存在 blob 或其他一些 db 特定的大字段实现中,而在服务器上,您可以只创建一个文件系统,然后将路径保存在数据库中。这是我的首选方法,因为数据库在使用该表时保持响应。
如果您在本地运行服务器,则只需授予对计算机文件系统的访问权限,以便将文件保存在那里。
使用 java 在服务器上保存文件的示例是;
https://stackabuse.com/reading-and-writing-files-in-java/
我可以建议您在实施实施之前好好阅读一下 java 和文件系统。
推荐阅读
- javascript - 如何在下一个 js 中使用本地或会话存储
- leaflet - 错误类型错误:无法读取未定义的属性“_leaflet_pos”
- scala - 使用scala.sys.process._时如何解决编译错误
- php - 在 PHP 上链接 js
- javascript - 你能在同一个域上获得一个外部 SVG 图像的 dataUrl 吗?
- python-3.x - Python:伪枚举 - 作为枚举的类 - 如何避免循环导入
- java - 尝试使用 size() 方法加载集合时如何解决 LazyInitializationException?
- python - 将图像坐标系的原点更改为中心
- sql - SQL Server - 存储过程意外结果
- java - 使用java将两个整数写入一个字节的高4位和低4位