设为首页 收藏本站
查看: 912|回复: 0

[经验分享] ASP.NET vNext 在 Mac OS

[复制链接]

尚未签到

发表于 2015-12-30 12:15:59 | 显示全部楼层 |阅读模式
让 ASP.NET vNext 在 Mac OS 中飞呀飞。。。



写在前面
DSC0000.png
  阅读目录:

  •   娓娓道来

    •   Install ASP.NET vNext Command Line Tools

      •   安装 Homebrew
      •   使用 Homebrew,安装 KVM

    •   Install Sublime Text 3
    •   Install Sublime Kulture Using the Package Control Plugin

      •   Install Package Control Plugin
      •   Install Sublime Kulture

    •   Samples Test

      •   Home 演示项目克隆到本地
      •   在 Sublime Text 3 中,打开 HelloMvc
      •   在 Sublime Text 3 中,恢复 NuGet 程序包
      •   在 Sublime Text 3 中,编译并运行 HelloMvc

    •   generator-aspnet

  •   写在最后
  前两天写了这样一篇博文《Building Modern Web Apps-构建现代的 Web 应用程序(一些感想)》,在博文的最后我有提到:
  我个人觉得 MSDN 应该是 .NET 程序员常去的社区,为什么?当你还在纠结 ASP.NET Web Forms 和 ASP.NET MVC 时,你所不知道的是,人家已经在 Mac OS 中使用 ASP.NET vNext 了。
  关于 Mac OS 中构建 ASP.NET vNext,虽然 ASP.NET vNext 正式版本还没发布,但是老外早就已经在尝试了,甚至有个哥们录制了一段视频上传到 YouTube,那我觉得咱们博客园也不能落后,下面摘自我在 Mac OS X 系统中构建 ASP.NET vNext 的一些笔记,希望对那些狂热 .NET 的童鞋们一些帮助。
  需要声明的是,其实我对 Mac OS X 系统以及 Mono 并不是很熟悉,因为当时时间有限,一些配置都是 Google 找的英文资料,所以有些地方我也是“知其然而不知所以然”,希望有时间可以深入研究下,本篇博文内容你可以当作一个教程来读。
娓娓道来
  首先,我先大致列一下,在 Mac OS X 系统中需要配置或安装的东西:

  • Mono
  • Homebrew
  • KVM (K Version Manager)
  • Sublime Text 3
  • Sublime Kulture
  • generator-aspnet
  • 大致就这么多吧。。。
1. Install ASP.NET vNext Command Line Tools
  这一部分我们的目的是:To install KVM(K Version Manager) and the correct version of Mono on OS X using Homebrew.
1.1 安装 Homebrew
  什么是 Homebrew?
  Homebrew is the easiest and most flexible way to install the UNIX tools Apple didn’t include with OS X.
  我们能够通过终端方便的使用它安装管理苹果没有自带的 UNIX 相关工具软件,这个很重要,因为下面我们所进行的安装都是在“终端命令”中进行的,Homebrew 安装命令为:
  ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)"
DSC0001.png
  Mac OS X 已经自带 ruby,所以我们可以直接使用 ruby,以上命令直接在粘贴在终端中执行,详细使用请参考:Homebrew
1.2 使用 Homebrew,安装 KVM

  • Run command brew tap aspnet/k to tap the ASP.NET vNext related git repositories.
  • Run command brew install kvm to install KVM. This also automatically install the latest KRE package from https://www.myget.org/f/aspnetmaster/api/v2 feed.
  • Run command source kvm.sh on your terminal if your terminal cannot understand kvm.
DSC0002.png
  注:下载并安装 KVM 花的时间会比较长,最后一个命令是检测 KVM 是否已经成功安装。
2. Install Sublime Text 3
  关于 Sublime Text,不管是 Windows,Mac OS,还是 Linux,我们应该或多或少的接触过,功能强大就不多说了。在 Mac OS 中打代码,虽然没有 Visual Studio,但是我们有 Sublime Text,下载地址:http://www.sublimetext.com/3
3. Install Sublime Kulture Using the Package Control Plugin
3.1 Install Package Control Plugin
  Package Control Plugin 是什么?它在 Sublime Text 中的作用,可以理解为终端在 Mac OS 中的作用一样,比如下面我们启动或编译 ASP.NET vNext 项目,就是通过 Package Control Plugin 命令,了解更多内容。
  两种安装方式,具体可参照官方说明:https://sublime.wbond.net/installation
  命令安装:

  • 打开 Sublime Text 3。
  • 按 Ctrl+` 或 View > Show Console,调出 Console。
  • 粘贴以下代码到底部命令行并回车:
    import urllib.request,os,hashlib; h = '7183a2d3e96f11eeadd761d777e62404' + 'e330c659d4bb41d3bdf022e94cab3cd0'; pf = 'Package Control.sublime-package'; ipp = sublime.installed_packages_path(); urllib.request.install_opener( urllib.request.build_opener( urllib.request.ProxyHandler()) ); by = urllib.request.urlopen( 'http://sublime.wbond.net/' + pf.replace(' ', '%20')).read(); dh = hashlib.sha256(by).hexdigest(); print('Error validating download (got %s instead of %s), please try manual install' % (dh, h)) if dh != h else open(os.path.join( ipp, pf), 'wb' ).write(by)
  • 重启 Sublime Text 3。
  • 如果在 Perferences->package settings 中看到 package control 这一项,则安装成功。
  如果命令安装方式不成功,请尝试手动安装(我当时好像就是这种方式安装的):

  • 打开 Sublime Text 3。
  • 选择 Preferences > Browse Packages…
  • 打开这个文件夹,进入 Installed Packages 文件夹(没有的话,自己创建一个)。
  • 下载 Package Control.sublime-package 文件,然后复制到 Installed Packages 文件夹下。
  • 重启 Sublime Text 3
3.2 Install Sublime Kulture
  Sublime Kulture 是什么?其实我也不是很清楚,你可以把它看作是 Sublime Text 3 支持 ASP.NET vNext 的一种插件,github 官方地址:https://github.com/ligershark/kulture/
  命令安装:

  • 打开 Sublime Text 3。
  • 按下 Cmd+Shift+P 调出命令面板。
  • 输入并选择 Package Control: Install Package。
  • 输入并选择 Kulture,然后进行安装。
DSC0003.png
  手动安装:

  • 打开终端,输入命令:cd file:///Users/{username}/Library/Application Support/Sublime Text 3/Packages/
  • 进入 Packages 目录下,输入命令:git clone https://github.com/ligershark/Kulture.git,将 Kulture 克隆到 Packages 文件夹下。
DSC0004.png
4. Samples Test
  做完以上操作,我们基本上就可以使用 Sublime Text 3 开发 ASP.NET vNext 应用程序了,我们使用 GitHub 上一个开源示例作为演示,地址:https://github.com/shirhatti/Home.git
4.1 Home 演示项目克隆到本地
  在 Mac OS 中随便找个目录,在终端中输入命令:git clone https://github.com/shirhatti/Home.git
DSC0005.png
  打开 Home > Samples 目录,我们会发现里面有三个项目文件夹:ConsoleApp,HelloMvc 和 HelloWeb,这边我们使用 HelloMvc(ASP.NET MVC),作为演示项目。
4.2 在 Sublime Text 3 中,打开 HelloMvc
  操作步骤:

  • 打开 Sublime Text 3,然后打开 File > Open,选择 HelloMvc 文件夹。
  • 打开 Tools > Build System,选择 ASP.NET 选项。
  Sublime Text 3 视图:
DSC0006.png
4.3 在 Sublime Text 3 中,恢复 NuGet 程序包
  演示项目 HelloMvc,是我们从 github 上克隆下来的源代码,但是项目依赖的程序包,需要我们手动恢复,恢复 NuGet 程序包步骤:

  • 按下 Cmd + Shift + P 调出命令面板。
  • 选择 Run K Commands 命令并回车。
  • 选择 kpm restore 命令并回车。
DSC0007.png
4.4 在 Sublime Text 3 中,编译并运行 HelloMvc
  编译命令:Cmd + B 或 F7,使用 Shft + F4 定位错误。
DSC0008.png
  启动并运行 HelloMvc:

  • 按下 Cmd + Shift + P 调出命令面板。
  • 选择 Run K Commands 命令并回车。
  • 选择 k kestrel 命令并回车。
  启动成功:
DSC0009.png
  我们可以在 peoject.json 中指定 host 地址,比如:"kestrel": "Microsoft.AspNet.Hosting --server Kestrel --server.urls http://localhost:5000"
  浏览器输入:http://localhost:5000/
DSC00010.png
5. generator-aspnet
  其实以上操作,我们只是根据现有项目编译并运行,那如何构建一个新的 ASP.NET vNext 应用程序呢?就像我们使用 Visual Studio New Project 一样,答案是 generator-aspnet。
  在安装 generator-aspnet 之前,必须先安装 node.js(This requires you to have node.js and npm already installed)。
  官方安装命令:npm install -g generator-aspnet,但是我安装的时候不知道怎么回事报错,具体什么原因我现在也记不得了,大概的解决方式是在命令之前加“sudo”,参考资料:latest angular generator throwing out so many errors on my macbook pro。
  安装命令(测试可行):

  • sudo npm install -g yo
  • sudo npm install -g generator-aspnet
DSC00011.png
  使用命令:yo aspnet,详细演示:

写在最后
  让 ASP.NET vNext 在 Mac OS 中飞呀飞,这个飞的过程,现在看来真是不太容易,前后断断续续花了三天时间,有些记录的地方可能也不是很准确,但不管怎样,总算分享出来了,如果无意间某一点的内容能帮到你,我觉得这个分享就值了。
  了解更多 ASP.NET vNext:

  • 振奋人心呐!关于下一代.NET——ASP.NET vNext 的更多说明
  • ASP.NET vNext 概述
  • 开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)
  • 分享我对 ASP.NET vNext 的一些感受,也许多年回过头看 So Easy!
  • POCO Controller 你这么厉害,ASP.NET vNext 知道吗?
  • 等待发现。。。
  本篇参考资料:

  • ASP.NET vNext - August 2014 Status Rollup
  • Develop ASP.NET vNext applications on a Mac
  • Sublime Kulture(youtube)

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-158312-1-1.html 上篇帖子: Mac os下安装pycurl 下篇帖子: Mac OS Alfred 2 tips
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表