GoView 简介
GoView 是一款基于 Vue3.x 构建的低代码数据可视化开发平台,允许开发者通过简单的配置快速构建各种数据可视化大屏。
- 官网文档:https://mtruning.club/
- 源码地址:https://gitee.com/MTrun/go-view
- .NET 扩展:https://gitee.com/sun_xiang_yu/go-view-dotnet
它具备低代码开发、丰富的组件库、响应式设计、数据驱动及主题定制等特点,特别适合企业级运营监控、数据分析看板等场景。
.NET 集成方案
在 .NET 项目中集成 GoView 通常有两种方式:前后端分离或嵌入式集成。本文将重点介绍第二种方式,实现 GoView 与.NET MVC 或 Razor Pages 的无缝融合。
集成步骤详解
1. 环境准备
确保本地已安装以下环境:
- .NET 6+ SDK
- Node.js(用于构建前端)
- Git(用于拉取源码)
2. 获取并构建 GoView
克隆仓库并安装依赖:
git clone https://gitee.com/MTrun/go-view.git
cd go-view
npm install
构建生产版本:
npm run build
完成后,项目根目录下会生成 dist 文件夹,包含所有静态资源。
3. 创建 .NET 项目
使用 CLI 创建一个 WebApp 项目:
dotnet new webapp -n GoViewDemo
cd GoViewDemo
4. 集成静态资源
将 GoView 构建后的 dist 文件夹内容复制到 .NET 项目的 wwwroot 目录下。目录结构大致如下:
wwwroot/
├── css/
├── js/
├── img/
├── favicon.ico
└── index.html
5. 修改路由配置
在 Program.cs 中配置静态文件服务和重定向规则,确保访问根路径时能正确加载 GoView 入口:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddRazorPages();
var app = builder.Build();
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
// 添加 GoView 路由,重定向到 index.html
app.MapGet("/", () => Results.Redirect("/index.html"));
app.MapRazorPages();
app.Run();
6. 配置 API 接口
在 .NET 中创建控制器提供 GoView 所需的数据:
// Controllers/GoViewController.cs
using Microsoft.AspNetCore.Mvc;
namespace GoViewDemo.Controllers;
[ApiController]
[Route("api/[controller]")]
public class GoViewController : ControllerBase
{
[HttpGet("chartData")]
public IActionResult GetChartData()
{
var data = new
{
categories = new[] { "周一", "周二", "周三", "周四", "周五", "周六", "周日" },
series = new[]
{
new { name = "邮件营销", data = new[] { 120, 132, 101, 134, 90, 230, 210 } },
new { name = "联盟广告", data = new[] { 220, 182, 191, 234, 290, 330, 310 } }
}
};
return Ok(data);
}
}
7. 修改前端配置
编辑 wwwroot/js/app.*.js 文件,修改 Axios 请求基础地址指向 .NET 后端:
axios.defaults.baseURL = '/api';
运行项目即可访问:
dotnet run
访问 https://localhost:5001 即可看到集成的 GoView 大屏。
进阶集成方案
1. 身份验证集成
若需保护接口,可在 .NET 中添加 JWT 认证,并在 GoView 前端配置拦截器自动携带 Token。
.NET 端配置:
builder.Services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
.AddJwtBearer(options =>
{
options.TokenValidationParameters = new TokenValidationParameters
{
ValidateIssuer = true,
ValidateAudience = true,
ValidateLifetime = true,
ValidateIssuerSigningKey = true,
ValidIssuer = builder.Configuration["Jwt:Issuer"],
ValidAudience = builder.Configuration["Jwt:Audience"],
IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(builder.Configuration["Jwt:Key"]))
};
});
GoView 前端拦截器:
axios.interceptors.request.use(config => {
const token = localStorage.getItem('token');
if (token) {
config.headers.Authorization = `Bearer ${token}`;
}
return config;
}, error => Promise.reject(error));
2. 动态主题切换
通过 API 控制主题,支持暗黑模式或明亮模式切换。
[HttpGet("themes")]
public IActionResult GetThemes()
{
return Ok(new[] {
new { id = "default", name = "默认主题" },
new { id = "dark", name = "暗黑主题" }
});
}
3. 数据缓存优化
使用 MemoryCache 减少数据库压力:
[HttpGet("cachedData")]
public async Task<IActionResult> GetCachedData([FromServices] IMemoryCache cache)
{
const string cacheKey = "chart_data";
if (!cache.TryGetValue(cacheKey, out var data))
{
// 模拟从数据库获取数据
data = await FetchDataFromDatabase();
var options = new MemoryCacheEntryOptions().SetSlidingExpiration(TimeSpan.FromMinutes(5));
cache.Set(cacheKey, data, options);
}
return Ok(data);
}
常见问题解决
跨域问题
开发环境中可配置 CORS 策略:
builder.Services.AddCors(options =>
{
options.AddPolicy("AllowAll", builder =>
{
builder.AllowAnyOrigin().AllowAnyMethod().AllowAnyHeader();
});
});
app.UseCors("AllowAll");
静态文件 404 错误
- 确保
UseStaticFiles中间件在管道中的位置正确。 - 检查文件路径大小写是否匹配。
API 请求路径
- 确保 GoView 配置的 API 路径与 .NET 路由一致。
- 优先使用相对路径而非绝对路径。
性能优化
启用响应压缩以提升传输效率:
builder.Services.AddResponseCompression(options =>
{
options.EnableForHttps = true;
});
app.UseResponseCompression();
总结
通过上述步骤,我们实现了 GoView 在 .NET 项目中的完整嵌入。这种方案既保留了 GoView 强大的可视化能力,又利用了 .NET 的后端稳定性。关键点在于静态资源的正确部署、API 接口的合理设计以及安全认证的集成。开发者可根据实际需求进一步扩展,构建企业级数据监控解决方案。


