eshop-mobile-client

eshop-mobile-client

基于.NET MAUI的跨平台移动电商应用示例

eshop-mobile-client是基于.NET MAUI开发的多平台电商应用示例,支持iOS、Android、macOS和Windows。该项目展示了产品目录管理、商品浏览、购物车操作和订单处理等核心功能。采用XAML、IoC容器、自定义控件等技术,呈现现代移动应用架构。开发者可选择连接实际微服务后端,深入体验完整的电商应用开发流程,是学习跨平台移动应用开发的理想参考。

.NET MAUI跨平台开发移动应用微服务eShopGithub开源项目

eshop-移动客户端

eShop示例应用程序已更新并移至https://github.com/dotnet/eShop。活跃开发将在那里继续。

eshop-移动客户端是一个参考.NET MAUI多平台客户端应用程序,其设想目的是为一家销售产品的虚构公司的移动员工提供服务。该应用程序允许您管理目录、查看产品以及管理购物篮和订单。

依赖项

虽然eshop-移动客户端移动应用依赖于eShopOnContainers仓库作为其后端,但默认情况下,它使用内部的MockServices实现所有功能。更多详情请参阅设置部分。

<img src="https://yellow-cdn.veclightyear.com/2b54e442/485f3bb0-8711-4f07-b462-275be4d8c0a3.png" alt="eShopOnContainers" Width="800" />

架构

应用程序架构包含两个部分:

  1. 一个适用于iOS、macOS、Android和Windows的.NET MAUI移动应用。
  2. 几个部署为Docker容器的.NET Web API微服务。

.NET MAUI应用

该项目涉及以下平台、框架和功能:

  • .NET MAUI
    • XAML
    • 行为
    • 绑定
    • 转换器
    • 中央样式
    • 动画
    • IoC
    • 消息中心
    • 自定义控件
    • xUnit测试
  • Azure移动服务
    • C#后端
    • WebAPI
    • Entity Framework
    • Identity Server 4

后端服务

所有与后端服务相关的代码和组件都在eShopOnContainers仓库中维护。

支持的平台

该应用针对四个平台:

  • iOS
  • Android
  • macOS(必须在Mac上构建和部署)
  • Windows(必须在Windows上构建和部署)

要求

  • Visual Studio 2022(2022或更高版本)以编译C#语言特性
    • 完全支持Visual Studio社区版!
  • Visual Studio的.NET MAUI插件(可通过Visual Studio安装程序获得)

设置

1. 确保已安装.NET MAUI平台

您可以按照安装.NET MAUI中提到的步骤进行操作。

2. 确保.NET MAUI已更新

Visual Studio会定期自动检查更新。您也可以使用更新Visual Studio选项手动检查更新。

3. 项目设置

恢复项目的NuGet包。

4. 确保已安装Android模拟器

您可以使用任何Android模拟器或设备。有关设置的详细信息,请参阅Android模拟器文档

注意:Android模拟器在虚拟机内或通过远程桌面或VNC无法正常运行,因为它依赖于虚拟化。

要在物理设备上部署和调试应用程序,请参阅在Android设备上调试文章。

5. 可选的iOS部署

要部署到iOS,您可以直接从Mac机器部署,或者可选择从Windows机器直接部署到设备,或通过将Windows机器与Mac配对

6. 使用实际微服务

默认情况下,eshop多平台客户端使用内部模拟服务,让用户探索应用程序中的不同功能集。

但如果您想使用真实服务测试应用程序,也可以这样做。

为此,您需要执行以下操作:

  1. eShopOnContainers仓库部署eShop应用程序的后端服务。您可以将应用程序部署到本地KubernetesAKS环境。

  2. 设置部分启用微服务端点。

<img src="https://yellow-cdn.veclightyear.com/2b54e442/4eff0a79-2078-42bf-9cf9-4522563f7d57.png" alt="启用微服务端点" Width="300" /> <img src="https://yellow-cdn.veclightyear.com/2b54e442/62c7dbc8-a616-4128-8b7a-e150d15fe6d1.png" alt="配置微服务端点" Width="300" />

身份URL:http://<您的IP或DNS名称>/identity 移动网关购物URL:http://<您的IP或DNS名称>/mobileshoppingapi

  1. 启用HTTP流量。

Android应用

您还需要在network_security_config.xml文件的<domain includeSubdomains="true"><您的IP或DNS名称></domain>部分中包含<您的IP或DNS名称>,以使用HTTP流量。

更多详情请参阅使用网络安全配置管理Android上的HTTP和明文流量

iOS应用

您需要确保您的info.plist文件包含以下配置。

<key>NSAppTransportSecurity</key> <dict> <key>NSAllowsArbitraryLoads</key> <true/> </dict>

更多详情请参阅退出ATS

**注意:**请注意,在生产环境中,您将使用HTTPS端点的服务。

7. 为Android设置Google地图

eShopOnContainers\Platforms\Android\AndroidManifest.xml中,您必须将com.google.android.geo.API_KEY的值替换为有效的Google地图API密钥。

<meta-data android:name="com.google.android.geo.API_KEY" android:value="您的密钥在这里" />

更多详情请参阅.NET MAUI地图 - 获取Google地图API密钥

截图

<img src="https://yellow-cdn.veclightyear.com/2b54e442/7c5e7875-7fb4-43db-a3c7-bb80072526d4.png" alt="登录" Width="210" /> <img src="https://yellow-cdn.veclightyear.com/2b54e442/ef575cbd-5fec-485a-b3d1-e09b750b593e.png" alt="登录" Width="210" /> <img src="https://yellow-cdn.veclightyear.com/2b54e442/e386f238-4489-4de8-978f-a17b27f02135.png" alt="目录" Width="210" /> <img src="https://yellow-cdn.veclightyear.com/2b54e442/c6a3737c-eca1-4249-aeb7-8333e3417d77.png" alt="个人资料" Width="210" /> <img src="https://yellow-cdn.veclightyear.com/2b54e442/90167f3e-4edb-4bdb-90f4-fbbad91a096e.png" alt="订单详情" Width="210" />

清理和重建

如果从仓库拉取更新时遇到构建问题,请尝试清理和重建解决方案。

故障排除

许可

本项目使用了一些需要注明出处的第三方资产:

版权和许可

  • 代码和文档版权2023 Microsoft Corp. 代码基于MIT许可发布。

编辑推荐精选

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
下拉加载更多