├── .gitignore ├── Linux └── change_RedHat's_yum.md ├── README.md ├── developing_applications_for_android_in_intellij_idea.md ├── git └── config_multi_pub_for_multi_repo.md └── intellij ├── images ├── add_support_framework.png ├── hql_search.png ├── idea-maven-run.png ├── import_eclipse_web_project.png ├── maven-jetty-plugin-run.png ├── project_structure.png ├── project_structure_modules_paths.png ├── project_structure_modules_sources.png ├── project_structure_sdks.png ├── project_strutcture_global.png ├── resource_bundle.png ├── resource_native_to_ascii.png ├── run_configurations_tomcat.png ├── show_line_numbers.png ├── source_autoscroll.png └── vcs_show_dir_status.png └── intellij_idea_use_documents.md /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | -------------------------------------------------------------------------------- /Linux/change_RedHat's_yum.md: -------------------------------------------------------------------------------- 1 | ## RedHat 6.0 X32更换CentOS yum 2 | 由于RedHat的yum是需要官网注册购买服务才可用的,所以我需要更换为CentOS的yum软件以及更换为Cent OS的源才可以在RedHat中正常使用yum,不过暂时感觉yum还是远远落后于apt-get的,例如tmux在官方源中就没有. 3 | 4 | 首先说下基本思路,这个是6.0的版本的例子,如果是其他版本可以参照这个道理是一样的,根据http://mirrors.163.com/centos/6/os/i386/ ,基本可以推断出不同的版本以及不同的CPU的URL,例如如果你是RedHat6.3,基本就是http://mirrors.163.com/centos/6.3/ ,下面罗列的基本就知道个大概只需要根据这个更换下面的url地址就可以了.还有就是RedHat的版本和CentOS的版本应该是一致的,直到当前完成文档的时间,如果你RedHat是6那么建议你选择对应的6的CentOS的版本的软件比较合适。 5 | 6 | 首先删除原有的yum: 7 | 8 | rpm -aq|grep yum|xargs sudo rpm -e --nodeps 9 | 10 | 下载CentOS的yum: 11 | 12 | cd ~;mkdir soft;cd ~/soft 13 | wget http://mirrors.163.com/centos/6/os/i386/Packages/yum-3.2.29-40.el6.centos.noarch.rpm 14 | wget http://mirrors.163.com/centos/6/os/i386/Packages/yum-metadata-parser-1.1.2-16.el6.i686.rpm 15 | wget http://mirrors.163.com/centos/6/os/i386/Packages/yum-plugin-fastestmirror-1.1.30-14.el6.noarch.rpm 16 | 17 | 当前soft目录应该只有3个rpm,所以直接执行下面命令: 18 | 19 | sudo rpm -ivh *.rpm 20 | 这个时候需要下载源地址: 21 | 22 | cd /etc/yum.repos.d/ 23 | wget http://mirrors.163.com/.help/CentOS6-Base-163.repo 24 | 25 | 这样执行下面的脚本,可以把其中$releasever的替换为6就替换完成了: 26 | 27 | sed -i 's/\$releasever/6/g' CentOS6-Base-163.repo 28 | 29 | 然后把yum的缓存清除,根据当前的源更新缓存即可: 30 | 31 | sudo yum clean all 32 | sudo yum makecache 33 | 34 | ## RedHat5.7更换yum 35 | 原因和6一样,但是步骤少许区别,继续更换为CentOS的源,非常感谢163提供这么方便的哈。 36 | 37 | 主要步骤就是更改repo的源文件为163的,然后import key文件,然后你就可以使用了。 38 | 39 | ### 更改源 40 | 修改rhel源设置文件,路径为:/etc/yum.repos.d/rhel-debuginfo.repo。为以防万一,建议先将此文件做下备份。其他两个文件(redhat.repo,rhel-source.repo)均不需要修改。 41 | 42 | cd /etc/yum.repos.d/ 43 | cp rhel-debuginfo.repo rhel-debuginfo.repo.bk 44 | 45 | 修改rhel-debuginfo.repo文件为以下内容,直接粘帖即可: 46 | 47 | [base] 48 | name=Red Hat Enterprise Linux 5 -Base 49 | baseurl=http://mirrors.163.com/centos/5/os/$basearch/ 50 | gpgcheck=1 51 | [update] 52 | name=Red Hat Enterprise Linux 5 -Updates 53 | baseurl=http://mirrors.163.com/centos/5/updates/$basearch/ 54 | gpgcheck=1 55 | [extras] 56 | name=Red Hat Enterprise Linux 5 -Extras 57 | baseurl=http://mirrors.163.com/centos/5/extras/$basearch/ 58 | gpgcheck=1 59 | [addons] 60 | name=Red Hat Enterprise Linux 5 -Addons 61 | baseurl=http://mirrors.163.com/centos/5/addons/$basearch/ 62 | gpgcheck=1 63 | 上面修改的部分和6的对比可以看到版本不是完全对应的,这个具体可以先到5.7的目录去查看ReadME,已经说明5.7的需要使用5的即可。 64 | 65 | ### 导入key 66 | 67 | rpm --import http://mirrors.163.com/centos/5/os/x86_64/RPM-GPG-KEY-CentOS-5 68 | 69 | 然后就可以直接使用了,例如`yum install gcc`,如果可以正常执行就说明成功了。 -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | Documents 2 | ========= 3 | 4 | 主要存放自己的一些文档记录,包括一些工具的使用或者一些自己的经验累计,不过怎么看都像应该存放在blog中的内容呢 5 | -------------------------------------------------------------------------------- /developing_applications_for_android_in_intellij_idea.md: -------------------------------------------------------------------------------- 1 | #如何在Mac上实用IntelliJ开发android的Hello World 2 | 其实只是一个环境的搭建而已,只是把自己遇到的问题整理下和大家共享,可以解决部分新手的疑惑. -------------------------------------------------------------------------------- /git/config_multi_pub_for_multi_repo.md: -------------------------------------------------------------------------------- 1 | 如果使用git作为版本控制,那么相信每个人都有一个github的帐号来存储一些自己的项目,公司内部会有自己的远程库,这样的话如果只使用一个默认的pub key的话就会出现冲突没法同时使用。不过这个支持起来不费劲。 2 | 3 | ## 详解 4 | 5 | 只需要做以下几个步骤就可以了,根据下面操作: 6 | 7 | ssh-keygen -t rsa -f github -C "xx@gmail.com" 8 | ssh-keygen -t rsa -f gitlab -C "xx@gmail.com" 9 | ,后密码可以为空即可。这样就会在用户的.ssh目录下生成两个pub key和2个private key。如下: 10 | 11 | gitlab gitlab.pub github github.key 12 | 这样配置好了以后在`~/.ssh`目录下面执行先`touch config`,然后写入以下内容即可: 13 | 14 | host github.com 15 | HostName github.com 16 | User git 17 | IdentityFile ~/.ssh/github 18 | host git.itari.com.cn 19 | HostName git.itari.com.cn 20 | User git 21 | IdentityFile ~/.ssh/gitlab 22 | 23 | 然后保存,大功告成。 24 | 25 | ## 最后 26 | 27 | 如果存在两个远程的时候,还有一个问题就是git默认是配置了全局的user.email和user.name,这样如果两个远程你用了完全不同的用户名和邮箱就会出现问题,暂时的解决思路应该是这样:如果你公司的用的特别频繁,就配置全局的为公司的帐号和用户名,那么github的项目在项目中单独配置user.email和user.name。如果有其他方式欢迎补充。 28 | -------------------------------------------------------------------------------- /intellij/images/add_support_framework.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/add_support_framework.png -------------------------------------------------------------------------------- /intellij/images/hql_search.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/hql_search.png -------------------------------------------------------------------------------- /intellij/images/idea-maven-run.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/idea-maven-run.png -------------------------------------------------------------------------------- /intellij/images/import_eclipse_web_project.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/import_eclipse_web_project.png -------------------------------------------------------------------------------- /intellij/images/maven-jetty-plugin-run.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/maven-jetty-plugin-run.png -------------------------------------------------------------------------------- /intellij/images/project_structure.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/project_structure.png -------------------------------------------------------------------------------- /intellij/images/project_structure_modules_paths.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/project_structure_modules_paths.png -------------------------------------------------------------------------------- /intellij/images/project_structure_modules_sources.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/project_structure_modules_sources.png -------------------------------------------------------------------------------- /intellij/images/project_structure_sdks.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/project_structure_sdks.png -------------------------------------------------------------------------------- /intellij/images/project_strutcture_global.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/project_strutcture_global.png -------------------------------------------------------------------------------- /intellij/images/resource_bundle.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/resource_bundle.png -------------------------------------------------------------------------------- /intellij/images/resource_native_to_ascii.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/resource_native_to_ascii.png -------------------------------------------------------------------------------- /intellij/images/run_configurations_tomcat.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/run_configurations_tomcat.png -------------------------------------------------------------------------------- /intellij/images/show_line_numbers.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/show_line_numbers.png -------------------------------------------------------------------------------- /intellij/images/source_autoscroll.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/source_autoscroll.png -------------------------------------------------------------------------------- /intellij/images/vcs_show_dir_status.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ethanfu/Documents/ee3324c4317a72b1068bdb24cf1e2e71cc1045b7/intellij/images/vcs_show_dir_status.png -------------------------------------------------------------------------------- /intellij/intellij_idea_use_documents.md: -------------------------------------------------------------------------------- 1 | #从Eclipse转移到IntelliJ IDEA一点心得 2 | 本人使用IntelliJ IDEA其实并不太久,用了这段时间以后,觉得的确很是好用。刚刚从Eclipse转过来的很多人开始可能不适应,我就把使用过程中的一些经验和常用功能分享下,当然在看这篇之前推荐你先看完[IntelliJ IDEA 的 20 个代码自动完成的特性](http://www.oschina.net/question/12_70799),这篇文章对自动完成的特性介绍的非常好,只是快捷键说明部分还可以更完善一些,可以照顾下默认绑定键位不一致的童鞋。本文在说明快捷键的时候是根据Mac OSX 10.5+的默认keymap,当然也会提供相关的文字说明,如果和我的绑定不一致的可以直接去keymap中搜索即可。 3 | 4 | ## 基本设置 5 | ### 显示行号 6 | 这个以前在Eclipse中是个很简单的问题,转移到IntelliJ上以后的一些人也问过这个问题。使用同样的方式设置了以后发现只是对当前文件起作用了,打开另外一个文件依然没有行号。就好比你只是在vim中执行命令`set number`,而不是在.vimrc中设置一样的效果。这个是需要在IDE Settings中设置下的,如图所示勾选即可: 7 | ![image](images/show_line_numbers.png) 8 | 其他设置可参照该设置项勾选即可,例如显示空格等等. 9 | 10 | ### 文件和导航关联 11 | 我们在写代码的时候经常需要打开某个文件的时候,想在左边的文件树上自动打开关联到位置,这样很方便的找寻本目录下的其他文件或者其他的相关文件,其实这个IntelliJ提供了好几种解决方案,第一个就是和Eclipse一样的方式,如下: 12 | 13 | * 以前在Eclipse中设置也很简单,但是IntelliJ里面稍微有点不一样,如果想临时一次的话,打开文件的时候点击下图的小地球(第一眼看的时候很像个小地球仪)图标即可 14 | ![image](images/source_autoscroll.png) 15 | 如果你想和Eclipse的那个一样,让这一切自动的话,那么在上图的浮层中可以看到两个选项`AutoScroll to Source`和`AutoScroll from source`,IntelliJ很人性化的分了两个设置在里面,你两个都勾选就是基本和Eclipse的功能保持了完全一致,只是勾选一个自然也可以. 16 | 17 | 还有一种方式就是利用IntelliJ提供的**Navigation Bar**,IntelliJ很多功能操作都可以键盘化,这个就是喜欢键盘化操作的人的必备功能,操作方式就是打开文件的时候,使用快捷键`⌘+UP (Jump to Navigation Bar)`,然后就会出现一个下拉,基本就是这个文件所在目录的文件列表,还可以使用**上下左右的键位**来选择其他目录,是不是很酷? 18 | 19 | **备注:**此处建议把`View > Navigation Bar`的选项点掉,这样就使用快捷键之后就会在你鼠标的位置出现,感觉会更输入一些,当然这样你就基本失去了使用鼠标的权利,这个需要你根据个人癖好使用即可。 20 | 21 | ## 快捷键使用 22 | 如果你是苹果电脑用户的话,建议你改成Mac OSX 10.5+的键位绑定,因为Mac OSX 10.5这个兼容Windows的版本的键位实在是太蹩脚了,用着是真难受,好比你默认习惯`⌘+w`是关闭标签,在这个键位绑定中竟然是根据符号选择文本的一个快捷键. 23 | 24 | 这里主要介绍几个可能大家常用的,或者是你可能并不知道IntelliJ中有的几个快捷键,特别常用的你直接参照官网的Keymap介绍[Getting Started](http://www.jetbrains.com/idea/documentation/index.jsp)就可以了。学会在Keymap中自己查询需要的快捷键是主要的,不要每次都打开那个没用的百度,具体可以参照本文最后给出的链接。 25 | ### Outline调出 26 | 以前在Eclipse中用的很多的一个快捷键就是`ctrl+o`,这样可以调出代码文件的所有成员变量和方法,并且可以支持搜索很是方便,IntelliJ这种基本的功能自然是有,新手的话还经常问,这个在IntellJ中的快捷键是`⌘+F12 (File Structure)`。如果你不是Mac OSX 10.5+键位绑定的话,小括号中的内容就是你可以去Keymap中去搜索的内容。 27 | 28 | ###基本操作 29 | 30 | * **复制整行或者块:**在Eclipse中使用`ctrl+alt+Up`,IntelliJ默认是`⌘+D (Duplicate Line or Block)`,其实这个和Eclipse中的有差距,尤其是多行的时候或者选中内容的时候,不信你可以试试。所以你可以把Keymap中的`Duplicate Lines`定义上一个快捷键,我定义的是`Option+D`,这个键位在我的默认绑定中是没任何快捷键的,你可以自己绑定一个试试。 31 | * **根据符号选择文本:**这个键位用的太多了,并且也是非常的好用,举个例子,有这样一行代码`SpringSource Milestones Proxy` 你光标在Milestones中的某一个位置,你想替换`SpringSource Milestones Proxy`为其他单词,假设想替换为`Test XX`,其实这样你只需要`Option+Up (Select Word at Caret)`两下就可以选中你想要的单词了,当你想在开发过程中,你会发现这个键位用的太多了,多到换了其他没有这个键位的编辑器或者IDE上,很是不习惯。 32 | * **删除整行:** 可以直接`⌘+delete (Delete Line)`或者利用IntelliJ智能的功能,剪切的快捷键,当本行选中文本的时候剪切``⌘+x`会按照选中的文本实现剪切,但是你本行内无任何选中文本的时候会自动剪切整行,那么自然就类似一个删除本行的快捷键,但是这个其实还是比较蹩脚的,建议使用`⌘+delete`。 33 | * **想直接跳转到接口的实现方法:** `⌘+option+鼠标单击`或者`⌘+option+B`。 34 | * **语句自动完成 Statements completion:**这个在[IntelliJ IDEA 的 20 个代码自动完成的特性](http://www.oschina.net/question/12_70799)中已经说明,这里还是着重说下,因为的确很好用,也强烈推荐下,还有文中说的`智能自动完成 ctrl+shift+Space`,当给你的提示太多的时候,这个键绝对会给你惊喜. 35 | * **同样单词之间跳转:**在Eclipse中的快捷键是`ctrl+k`,这个挺好用的,在IntelliJ中也不缺这个功能,但是在Mac OSX 10.5+的键位绑定中默认为空。据说Windows的默认绑定中是有绑定的,自己可以查询下,我自己绑定了一个`⌘+ctrl+k (Find Word at Caret)`,没有的需要自己绑定一个,然后还能结合其他的键位实现上一个`⌘+G (Find Next)`下一个`⌘+Shift+G (Find Previous)`的功能.很是实用。 36 | 37 | ##版本控制设置 38 | 我们开发肯定是有版本控制的,大家以前Eclipse的时候在本地文件和版本库不一致的时候,那么文件以及所在的文件夹都会出现一个`〉`表示,大家能很轻松的看到本地文件修改了哪一些,但是IntelliJ中默认是不能这样的。仅仅是给变化的文件在修改的时候提供了颜色上的变化,不包括其所在的各个父级文件夹哦,如果想和Eclipse一样的话需要如下图把设置勾选就可以了 39 | ![vcs_show_dir_status](images/vcs_show_dir_status.png) 40 | 其实看英文解释就可以明白了,这个默认开启以后如果想调整文件夹的显示颜色的时候就直接去`Settings > Editor > Colors & Fonts > File Status`中调整即可了,可以调整成自己喜欢的样子。 41 | 42 | ##Java资源文件非英文的情况显示 43 | IntelliJ在资源文件这方面个人觉得也是完胜Eclipse的,在Resource Bundle方式下想修改一个属性是相当方便的,可以在一个操作界面上修改所有语言的属性,这一切都是自动完成的,如下图所示: 44 | ![resource_bundle](images/resource_bundle.png) 45 | 46 | 并且还很贴心的有一个排序和分组的功能,尤其是这个排序。 47 | 48 | 默认设置下也有一个问题,就是中文默认会显示为Unicode码的,其实勾选一个设置(`Settings > File Encodings`)就可以了,如下图: 49 | ![resource_native_to_ascii](images/resource_native_to_ascii.png) 50 | 51 | 这样设置以后所有Unicode显示的就可以自动转化为其应该显示的语言了. 52 | 53 | ## 符合Maven约定结构的web项目如何更好的运行 54 | 记得刚开始用Eclipse的时候那时候默认是不支持Java EE项目的,必须使用一个MyEclipse的插件,直到今天好似还有人在用这个玩意,当年的时候每个Web项目修改之后都必须Deploy一下,修改的东西才会被执行,很是痛苦。后来就自己利用Tomcat插件,这个可以保证你修改jsp以及静态文件的时候不需要Deploy直接就可以被执行,因为Tomcat的目录指向其实直接是指向到了你的项目文件,这样的确省心了很多。 55 | 56 | 在IntelliJ中如果你是传统的Java EE的结构(根目录下面有src,webMoudle这样的结构),那么在直接在Run Configurations中添加一个Tomcat即可,点击+号添加即可(当然需要注意虽然没搜索框,你输入字符会自动给你筛选结果),这样运行的时候修改Java文件的话需要主动Make Project也就是`⌘+F9 (Make Project)`.但是如果你是符合maven约定的项目结构的话如果继续这样配置就很不理想了,每次修改了jsp文件竟然也需要Make Project才可以,因为每次Make Project以后IntelliJ会自动给你DeployMent,这样好似又回到了几年前那种很麻烦的环境. 57 | 58 | 这个问题其实很容易解决,就是不要使用这种方式来运行你的web项目,既然符合maven结构的项目自然是使用maven或者gradle这种构建工具了,那么你需要利用maven的jetty的插件来运行项目即可了,如下图配置即可: 59 | ![idea-maven-run](images/idea-maven-run.png) 60 | 61 | 当然你也可以如下图直接点击运行就会自动添加一个: 62 | 63 | ![maven-jetty-plugin-run](images/maven-jetty-plugin-run.png) 64 | 参看上图其实也没必须非用jetty,用tomcat6或者tomcat7的插件运行也可以。 65 | 66 | ##Eclipse的web结构项目如何导入和运行 67 | 鉴于有一些用户还没转型Maven等来构建项目,当然我也衷心的说一句,构建这块还是赶紧转了吧.因为不转的话还单独出来这个章节,并且有的操作还是相当麻烦,下面也会讲到,还是一一道来吧,导入的时候有两个选择然后我分两个部分说明,点击`File > Import Project…`,然后选择你的项目目录,点击OK,如下图: 68 | 69 | ![image](images/import_eclipse_web_project.png) 70 | 71 | ### 使用新建项目来导入 72 | 这个方式图中所示的第一种,导入基本就是一路next到完成,但是你第一次也可以费点心思注意下每一步做了啥,例如帮你分析了jar有哪一些,如果你使用了Spring还给你分析你的所有配置文件。最后完成以后项目就开始构建索引,等一切就绪以后我们就可以完成的基本配置了,由于是web项目基本上能够在Tomcat等服务器上跑起来就基本算成功了。主要几个点: 73 | 74 | * 处理好依赖关系,因为我们没使用maven,所以你得自己动手丰衣足食了 75 | * 设置java文件的编译路径,如果需要的话 76 | * 添加你的Tomcat,运行成功 77 | 78 | #### 依赖关系 79 | 打开`File > Project Structure` ,本节我们主要用到下图几个标红的部分: 80 | ![project_structure](images/project_structure.png) 81 | 我们先了解下这几个主要部件: 82 | 83 | * **SDKs:**主要存放了我们的JDK等,如下图(我自己下载带source的JDK,这样可以直接查看JDK相关的Java源代码): 84 | ![project_structure_sdks](images/project_structure_sdks.png) 85 | * **Global Libraries:**主要是公用的jar文件,例如servlet的几个jar可能每个项目都需要,但是Eclipse的变量在此变得不好使,所以需要使用这个地方来配置,如下图参照使用即可: 86 | ![project_strutcture_global](images/project_strutcture_global.png) 87 | * **Facets:**在此不做介绍,如有需要后续添加 88 | * **Libraries:**这里基本是项目的库,不是全局的,导入的项目一般都会把你Eclipse中的。classpath中的所有的依赖都导过来作为一个lib库,然后应用到你的项目的模块中 89 | * **Modules:**这个基本包括了项目的模块,通常来说Eclipse的项目结构中是单模块的 90 | 91 | 我们需要做的配置主要在Modules中,其他的几个自己根据理解配置即可。 92 | 93 | 1. 我们先查看**Modules**中的**Sources**,如下图: 94 | ![project_structure_modules_sources](images/project_structure_modules_sources.png) 95 | 把项目所有的源码都添加即可,图中所示我的项目中其实少了resource的文件夹,这样我选中resource然后点击Sources即可,这样就会在左边的Source Folders中添加一个resource的文件夹。 96 | 2. 然后是Paths部分,这个主要是class的输出路径,默认是在根目录下的out文件夹中,如果项目中对配置文件的解析等有写死路径,必须严格遵循Java EE的规范的话,那么需要将此部分修改如下(如果不存在我假设的情况可忽略本步骤): 97 | ![project_structure_modules_paths](images/project_structure_modules_paths.png) 98 | 3. 然后的Dependencies,就更好配置了,添加需要的依赖即可。 99 | 100 | 这些步骤完成以后我们就可以点击`Run > Edit Configurations` ,点击左上角的**+**号,然后选择**Tomcat > Local Server **,这些步骤和Eclipse类似,选择相应路径等等,只需要注意一点就可以,就是需要添加一个DeployMent,如下图: 101 | ![run_configurations_tomcat](images/run_configurations_tomcat.png) 102 | 103 | **如果是Windows的图中的DeployMent中的+号可能是在右侧**,点击之后会弹出对话框选择文件夹,选择eclipse默认的webMoudle文件夹即可(MyEclipse就是WebRoot文件夹),这个一定不能选错,不要选成项目的主文件夹,否则运行就不成功了,再然后`ctrl+R`运行即可。以debug方式运行就是`ctrl+D`。 104 | 105 | 106 | 107 | ### 使用IntelliJ对Eclipse项目的支持导入项目 108 | 基本参照上个基本都类似,就是步骤比上个步骤要少点,如果出现问题参照上个章节即可。 109 | 110 | ## HQL查询支持 111 | 以前Eclipse有个HQL的插件可以直接输入HQL语法,查询测试结果是否正确,在IntelliJ中你也可以,不过不需要任何插件默认提供支持的,如果在导入项目的时候没有自动添加Hibernate的支持的话,那需要添加一下Hibernate的支持,鼠标选中项目,点击右键如下图: 112 | ![image](images/add_support_framework.png) 113 | 点击选择Hibernate即可,如果没有Hibernate应该是项目已经自动添加了Hibernate的支持了。然后完成以后就可以如下图操作即可: 114 | ![image](images/hql_search.png) 115 | 选中上面HQL图标,在出来的控制台输入你想输入的HQL即可了,一样可以自动完成的哦。 116 | 117 | ## 注意事项 118 | 1. IntelliJ对于文件是默认随时保存的,基本不需要你`⌘+s`(这个键位默认是保存所有),所以需要注意不要随手不小心把某个文件改了下,然后直接关闭标签了,其实你的无意的操作已经导致修改了文件,可能导致你在项目运行的时候发现一个很离奇的错误,我暂时没发现可以关闭自动保存的设置,如果你对此非有强迫症的话,vim的插件可能会帮助到你。 119 | 2. IntelliJ中的文件是实时和本地文件同步的,所以Eclipse的刷新功能就不要问了,因为在这根本不需要那个功能。有的编辑器会提醒你是否和本地文件更新,这里也是默认不给任何提醒的,只要你修改了,这里就会立即自动同步更新文件。 120 | 3. 在主菜单`File`下面,有个奇怪的Power Save Mode,这里也说明下,这个顾名思义是省电模式。当你勾选此模式以后,IntelliJ不会给你完成任何自动完成的功能,例如本来你输入一个字符会自动提示的,勾选以后就没有了,如果出现此问题的话可以考虑是不是自己手贱点过这个按钮噢,这个还是比较适合开会的时候无聊看代码用的,又省电又不影响你看代码。 121 | 4. Eclipse中有个`F2`的功能,可以查看到Java文件定义,你在Spring的配置文件中可能需要配置这个值,但是在IntelliJ中这个是不需要的,因为对于Spring这样的支持很是完善,你只需要在class的属性中输入class的名字然后`ctrl+空格 (Basic 这个在code的completion下面)`自动就完成了全路径,在智能的条件下可能就不需要蹩脚的实现。 122 | 5. 项目刚开始导入或者清除cache重新打开的时候,下面的状态栏部分会显示Indexing,这个时候你就等着就可以了,基本你想做的事情什么都不能做,别在这个时候着急点来点去,不过它索引的速度挺快的,别着急。 123 | 6. Eclipse有个Save Actions的功能,主要是针对Java可以自动格式化以及优化import等功能,这个在IntelliJ上其实默认是没有的,想在IntelliJ中使用这功能可以使用以下两个思路: 124 | * 利用**宏录制**,宏在开始以后你就格式化下代码,然后优化下import等操作,然后结束把宏定义一个`⌘+s`,不过问题就是不管什么文件都会执行这个宏,不仅仅是java文件,我就是利用这个宏主要完成把tab转为空格。 125 | * 使用**Eclipse Code Formatter**的插件,这个插件基本和Eclipse默认的功能类似,但是也有少许区别,用户自己思量是否使用即可。 126 | 7. 在Mac下IntelliJ代码区域是支持手势放大的,这个在给别人演示的时候很是方便。但是Run、Debug等视图的时候默认能使想到的就是手动的拖动大小,很是不便。你可以尝试下`⌘+shift+up/down (Stretch to Top / Bottom)`,当然其他的project视图等的也都可以利用这个快捷键配置上下左右的方向键来配置使用,方便的很,强烈推荐使用。 127 | 8. Eclipse中可以同一个窗口打开多个项目,但是IntelliJ IDEA在这里的设计是不一样的,具体可以参看[IntelliJ IDEA Q&A for Eclipse Users](http://www.jetbrains.com/idea/documentation/migration_faq.html)。 128 | 9. jar的source依赖问题,如果你是使用Maven的话都是可以自动完成的,只需要你发布出你的source jar就可以,但是如果你项目不是使用maven的话你就需要在项目配置的依赖的地方,点击你的需要引入source的jar,然后右键编辑,add你的本地source目录就可以了,不需要做Project的多个moudle即可,这里和Eclipse中的基本相似。 129 | 130 | 131 | ## 最后 132 | 133 | 第一次发文,如果有什么问题欢迎留言交流,原始文档放在[github](https://github.com/fxl545826/Documents)上,各位如果也有一些技巧不妨共同完善下本文档。只需要Fock然后Pull Request就可以了,如果你觉得有个github帐号过于麻烦的话,那我个人觉得你还是转行比较合适。如果不想更新只是想订阅持续更新的内容,只需要Watch该项目即可。还可以对项目Star,这样你就可以在自己的帐号页面快速找到本项目。 134 | 135 | ## 附录 136 | * Win快捷键 [Win Keymap](http://www.jetbrains.com/idea/docs/IntelliJIDEA_ReferenceCard.pdf) 137 | 138 | * Mac OS 快捷键 [Mac OS Keymap](http://www.jetbrains.com/idea/docs/IntelliJIDEA_ReferenceCard_Mac.pdf) --------------------------------------------------------------------------------