3
我需要編寫一個網站來顯示我們團隊的推送信息。現在我遇到了一個問題,如何從gitlab獲取信息?如何從.NET的gitlab掛鉤獲取推送信息
我需要編寫一個網站來顯示我們團隊的推送信息。現在我遇到了一個問題,如何從gitlab獲取信息?如何從.NET的gitlab掛鉤獲取推送信息
推送信息的類型是JSON,你需要做的是向gitlab添加一個URL鉤子,並且這個url是你的API的地址。 就像:
,然後點擊測試按鈕檢查您API
以下是我的push_events API,:
public int PushEventInfo([FromBody]PushEvent push)
{
bool flag = true;
ProjectController project = new ProjectController();
List<string> projectName = new List<string>();
try
{
SqlConnection conn = connectLocaldb.ConnectDataBase();
conn.Open();
string sql = "INSERT INTO MemberCommitBeforeCompiling(Username,ProjectName,Version,GroupName,CommitTime,Branch) VALUES ('" + push.user_name + "','" + push.project.name + "','" + push.after + "','" + groupname + "',getdate(),'" + [email protected] + "') ";
SqlCommand cmd = new SqlCommand(sql, conn);
int result = cmd.ExecuteNonQuery();
//判斷項目是否已存在
IList<Project> namelist = project.GetAllProjectInfo();
foreach(var i in namelist)
{
//如果MemberProject表中已經存在該項目
if (i.projectName.Contains(push.project.name)|| push.project.name.Contains(i.projectName))
flag = false;
}
if (flag==true)
{
sql = "INSERT INTO MemberProject(ProjectName,CommitTime,isdelete) VALUES ('" + push.project.name + "',getdate(),'0') ";
cmd = new SqlCommand(sql, conn);
result = cmd.ExecuteNonQuery();
}
conn.Close();
return result;
}
catch (Exception e)
{
FileStream fs = new FileStream("c:\\test\\log.txt", FileMode.Append, FileAccess.Write);
StreamWriter sw = new StreamWriter(fs); // 創建寫入流
sw.WriteLine(e.ToString()); // 寫入
sw.Close();
return 0;
}
加推JSON信息作爲模型類 – xiehongguang
我仍然當觸發push hook時,不會發生什麼API – xiaomifeng
,它會調用你的API並添加json作爲參數 – xiehongguang