在我的 Spring MVC 应用程序中,我在表示层中使用 DTO,以便在服务层中封装域模型。 DTO 被用作 spring 表单支持对象。
因此我的服务看起来像这样:
userService.storeUser(NewUserRequestDTO req);
服务层将翻译 DTO -> 域对象并完成其余工作。
现在我的问题是,当我想从服务中检索 DTO 以执行更新或显示时,我似乎找不到更好的方法来执行此操作,然后使用多种方法来查找返回不同的 DTO喜欢...
EditUserRequestDTO userService.loadUserForEdit(int id);
DisplayUserDTO userService.loadUserForDisplay(int id);
但这种方法感觉有些不对。也许服务不应该返回诸如 EditUserRequestDTO 之类的东西, Controller 应该负责从专用表单对象组装 requestDTO,反之亦然。
之所以有单独的 DTO,是因为 DisplayUserDTO 是强类型只读的,而且用户的许多属性是数据库中查找表中的实体(如城市和州),因此 DisplayUserDTO 将具有字符串属性的描述,而 EditUserRequestDTO 将具有支持表单中选择下拉列表的 ID。
你怎么看?
谢谢
最佳答案
我喜欢精简的展示对象。它比构建整个域对象只是为了显示它的几个字段更有效。我使用了类似的模式,但有一点不同。我没有使用 DTO 的编辑版本,而是在 View 中使用了域对象。它显着减少了在对象之间来回复制数据的工作。我还没有决定现在是否要这样做,因为我正在使用 JPA 和 Bean Validation Framework 的注释并且混合注释看起来很乱。但我不喜欢将 DTO 用于将域对象保留在 MVC 层之外的唯一目的。似乎很多工作没有多大好处。此外,阅读 Fowler 对 anemic objects 的看法可能会有用。 .它可能不完全适用,但值得思考。
第一次编辑:回复以下评论。
是的,我喜欢将实际的域对象用于一次对单个对象进行操作的所有页面:编辑、查看、创建等。
您说您正在获取一个现有对象并将所需的字段复制到 DTO 中,然后将 DTO 作为模型的一部分传递给您的模板引擎以用于查看页面(反之亦然用于创建)。那能给你带来什么?对 DTO 的引用并不比对完整域对象的引用更轻,而且您还需要复制所有额外的属性。没有规则规定您的模板引擎必须使用对象上的所有方法。
如果可以提高效率(无需构建关系图),我会使用一个小的部分域对象,尤其是对于搜索结果。但是,如果该对象已经存在,则在将其粘贴到模型中以呈现页面时,不必担心它有多大或有多复杂。它不会在内存中移动对象。它不会导致模板引擎压力。它只访问它需要的方法并忽略其余方法。
第二次编辑: 好点子。在某些情况下,您希望 View 可以使用一组有限的属性(即不同的前端和后端开发人员)。我应该在回复之前仔细阅读。如果我打算做你想做的事,我可能会在 User(或任何类)上放置单独的方法,形式为 forEdit() 和 forDisplay()。这样你就可以从服务层获取 User 并告诉 User 给你自己的使用限制副本。我想也许这就是我在贫血对象评论中所达到的目的。
关于java - Spring MVC : should service layer be returning operation specific DTO's?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2634669/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',
我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby1.9+ 关于ruby-主要:Objectwhenrun
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request
似乎无法为此找到有效的答案。我正在阅读Rails教程的第10章第10.1.2节,但似乎无法使邮件程序预览正常工作。我发现处理错误的所有答案都与教程的不同部分相关,我假设我犯的错误正盯着我的脸。我已经完成并将教程中的代码复制/粘贴到相关文件中,但到目前为止,我还看不出我输入的内容与教程中的内容有什么区别。到目前为止,建议是在函数定义中添加或删除参数user,但这并没有解决问题。触发错误的url是http://localhost:3000/rails/mailers/user_mailer/account_activation.http://localhost:3000/rails/mai