在尝试开发web阅读器时因为需要解决epub电子书格式的解析,我选择了ePub.js(其实也没别的库可以选择)
首先是关于ePub.js使用时的一些坑
1、这个库可以解析解压好的文件和压缩过的epub文件,但是要解析epub文件需要同时引入ePub.js和jszip两个库
2、解析epub文件必须使用静态资源,在后台返回流数据时怎么样都无法解析书本,并且脚本会尝试请求/META-INF/container.xml这个URI
3、现在网上所存在的关于epub.js的内容相当少,还有一些方法都已经没法使用,官方文档说明也不太清楚
关于第二点,我来分享下我的解决方法
首先,后台我使用的Springboot框架,所以我首先是将特定链接映射为静态资源地址,代码:
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
private String bookPath = "file:" + SettingUtil.BOOK_PATH;
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/epub/**").addResourceLocations(bookPath);
}
}
这样当访问/epub/这个链接时就相当于访问了对应的静态资源,当然这样的话可能会产生安全问题,所以在此基础上我在controller上添加了个接口:
@RequestMapping("/get/epub/**")
public void epubDownload(HttpServletResponse response, HttpServletRequest request) throws IOException {
Cookie user = BaseUtil.getCookieContent(request.getCookies(), SettingUtil.USER_COOKIE_ID);
String uri = request.getRequestURI();
if (user != null){
String uuid = user.getValue();
String bookName = uri.substring(uri.lastIndexOf('/'));
String newURI = "/epub/" + uuid + bookName;
response.sendRedirect(newURI);
}
并且添加一个拦截器用于确认用户身份,防止用户通过url访问其他人的资源:
public class BookDownloadInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
Cookie user = BaseUtil.getCookieContent(request.getCookies(), SettingUtil.USER_COOKIE_ID);
String uri = request.getRequestURI();
if (user != null){
String uuid = user.getValue();
String requestUuid = uri.substring(uri.indexOf("/epub/"), uri.lastIndexOf('/'));
return !uuid.equals(requestUuid);
}
return true;
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
}
至此通过后台获取epub资源的部分就完成了,关于epub.js的使用我会另外发帖说明